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Preface 

This manual assumes some prior knowledge of current and proposed SCSI, and PCI standards. For back¬ 
ground information, please contact: 

ANSI 

11 West 42nd Street 
New York, NY 10036 
(212) 642-4900 

Ask for document number X3.131-199X (SCSI-2) 

Global Engineering Documents 
15 Inverness Way East 
Englewood, CO 80112 

(800) 854-7179 or (303) 792-2181 (outside US.) 

Ask for document number X3.131-1994 (SCSI-2) orX3.253 (SCSI-S Parallel Interface) 

ENDL Publications 

14426 Black Walnut Court 
Saratoga, CA 95070 
(408) 867-6642 

Document names: SCSI Bench Referenccy SCSI Encyclopedia 

Prentice Hall 

Englewood Cliffs, NJ 07632 
(201) 161-5931 

Ask for document number ISBN 0-13-796855-8, SCSI: Understanding the Small Computer System 
Interface 

Symbios Logic Electronic Bulletin Board 
(719) 573-3562 

SCSI Electronic Bulletin Board 
(719) 574-0424 

Symbios Logic Internet Anonymous FTP Site 
ftp.symbios.com (204.131.200.1) 

Directory: /pub/ncrchips/scsi 

PCI Special Interest Group 
P.O. Box 10470 
Portland, OR 97214 

(800) 433-5177; (503) 797-4201 antemational); FAX (503) 234-6762 
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Chapter 1 

Introduction 


General Description 

The SYM53C876 PCI-Dual Channel SCSI Multi¬ 
function Controller is a PCI 2.1 compliant device. 
It implements two SYM53C875 PCI-to-Ultra SCSI 
controllers on a single chip. The SYM53C876 pre¬ 
sents only one load to the PCI bus, and uses one 
REQ/ - GNT/ signal pair in arbitration for PCI bus 
mastership. 

Two packaging options are available. The 208-pin 
PQFP provides a differential/single-ended SCSI 
interface on SCSI Function A and a single-ended 
interface on SCSI Function B.The 256-bump BGA 
provides a differential/single-ended interface on 
both SCSI Function A and SCSI Function B. 


The SYM53C876 provides a local memory bus for 
storage of the device’s ROM BIOS in flash memory 
or standard EPROMs. The SYM53C876 supports 
programming of local FLASH memory for updates 
to BIOS or SCRIPTS programs. 

The SYM53C876 reduces the requirement for sys¬ 
tem BIOS support and PCI bus bandwidth. It also 
supports the Wide Ultra SCSI standard. The 
SYM53C876 performs Wide Ultra SCSI transfers 
or Fast SCSI transfers, and improves performance 
by optimizing PCI bus utilization. Figure 1-1 illus¬ 
trates a typical SYM53C876 system and Figure 1-2 
illustrates a typical SYM53C876 board application. 
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Figure 1-2: Typical SYM53C876 Board Application 
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Wide Ultra SCSI Benefits 


The SYM53C876 integrates a high-performance 
SCSI core, a PCI bus master DMA core, and the 
Symbios Logic SCSI SCRIPTS™ processor to 
meet the flexibility requirements of SCSI, Fast 
SCSI, and Wide Ultra SCSI standards. It is 
designed to implement multi-threaded I/O algo¬ 
rithms with a minimum of processor intervention, 
solving the protocol overhead problems of previous 
intelligent and non-intelligent controller designs. 

The SYM53C876 is fully supported by the Sym¬ 
bios Logic SCSI Device Management System 
(SDMS™), a software package that supports the 
Advanced SCSI Protocol Interface (ASPI). SDMS 
provides BIOS and driver support for hard disk, 
tape, removable media products, and CD-ROM 
under the major PC operating systems. 


Wide Ultra SCSI Benefits 

Wide Ultra SCSI is an extension of the SCSI-3 
family of standards that expands the bandwidth of 
the SCSI bus and allows faster synchronous SCSI 
transfer rates. When enabled. Wide Ultra SCSI 
performs 40 mega-transfers per second during an 
I/O operation, which results in approximately dou¬ 
bling the synchronous transfer rates of Fast SCSI. 
The SYM53C876 can perform Ultra SCSI syn¬ 
chronous transfers at 20 MB/s. It can also perform 
Wide Ultra SCSI transfers at 40 MB/s. This advan¬ 
tage is most noticeable in heavily loaded systems, 
or large-block size applications such as video on- 
demand and image processing. 

Another advantage ofWide Ultra SCSI is that it 
significantly improves SCSI bandwidth while pre¬ 
serving existing hardware and software invest¬ 
ments. The SYM53C876 is compatible with all 
existing SYM53C875 software. 


SCSI TolerANT Technology 

The SYM53C876 features TolerANT® technol¬ 
ogy, which includes active negation on the SCSI 
drivers and input signal filtering on the SCSI 
receivers. Through active negation, the SCSI 
Request, Acknowledge, Data, and Parity signals 
are actively driven high rather than passively pulled 
up by terminators. Active negation is enabled by 
setting bit 7 in the STEST3 register. 

TolerANT receiver technology improves data 
integrity in unreliable cabling environments, where 
other devices are subject to data corruption. Toler¬ 
ANT receivers filter the SCSI bus signals to elimi¬ 
nate unwanted transitions, without the long signal 
delay associated with RC-type input filters. This 
improved driver and receiver technology helps 
eliminate double clocking of data, the single big¬ 
gest reliability issue with SCSI operations. Toler¬ 
ANT input signal filtering is a built in feature of 
the SYM53C876 and all Symbios Logic Fast SCSI 
and Ultra SCSI devices. 

The benefits ofTolerANT include increased 
immimity to noise on the deasserting signal edge, 
better performance due to balanced duty cycles, 
and improved Fast SCSI transfer rates. In addi¬ 
tion, TolerANT SCSI devices do not cause glitches 
on the SCSI bus at power up or power down, so 
other devices on the bus are also protected from 
data corruption. TolerANT is compatible with 
both the Alternative One and Alternative Two ter¬ 
mination schemes proposed by the American 
National Standards Institute. 
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SYM53C876 Benefits 


PCI Performance 

■ Fully PCI 2.1 compliant 

■ True Multi-function device as defined in PCI 
2.1 specification - presents only one load to the 
PCI bus 

■ Supports 32-bit word data bursts with variable 
burst lengths of 2,4, 8, 16, 32, 64 or 128 
dwords across the PCI bus 

■ Prefetches up to 8 dwords of SCSI SCRIPTS 

■ Bursts SCSI SCRIPTS op code fetches across 
the PCI bus 

■ Performs zero wait-state bus master data bursts 
at 132 MB/s (@ 33 MHz) 

■ Supports PCI Cache Line Size register 

■ Supports PCI Write and Invalidate, Read Line, 
and Read Multiple commands 

SCSI Performance 

■ Includes 4KB internal RAM on each channel 
for SCRIPTS instruction storage 

■ Wide Ultra SCSI Single-Ended Interface 

■ Performs Wide Ultra SCSI synchronous 
transfers as fast as 40 MB/s 

■ 536-byte DMA FIFO for more effective PCI 
and SCSI bus utilization 

■ SCSI synchronous offset of 16 levels 

■ Supports variable block size and scatter/gather 
data transfers. 

■ Minimizes SCSI I/O start latency 

■ Performs complex bus sequences without 
interrupts, including restore data pointers 

■ Reduces ISR overhead through a unique 
interrupt status reporting method 

■ Load and Store SCRIPTS instruction 


increases performance of data transfers to and 
from chip registers 

■ Supports target disconnect and later reconnect 
with no interrupt to the system processor 

■ Supports multi-threaded I/O algorithms in 
SCSI SCRIPTS with fast I/O context 
switching 

■ Expanded Register Move instruction support 

■ Software (drivers and SCRIPTS) compatible 
with SYM53C875 

■ Integrated clock doubler enables Ultra SCSI 
with 40 MHz SCSI clock input 

Testability 

■ Access to all SCSI signals through 
programmed I/O 

■ SCSI loopback diagnostics 

■ SCSI bus signal continuity checking 

■ Single-step mode operation 

■ Test mode (AND tree) to check pin continuity 
to the board 


Integration 

■ Dual Channel SCSI Multi-function Controller 

■ 3.3 V/5 V PCI interface 

■ Full 32-bit PCI DMA bus master 

■ Can be used as a third-party PCI bus DMA 
controller by using Memory to Memory Move 
instructions 

■ High performance SCSI core 

■ Integrated SCSI SCRIPTS processor 


Reliability 

■ 2 KV ESD protection on SCSI signals 

■ Typical 300 mV SCSI bus hysteresis 

■ Protection against bus reflections due to 
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impedance mismatches 

■ Controlled bus assertion times (reduces EMI, 
improves reliability, and eases FCC 
certification) 

■ Latch-up protection greater than 150 mA 

■ Voltage feed through protection (minimum 
leakage current through SCSI pads) 

■ Power and ground isolation of I/O pads and 
internal chip logic 

■ TolerANT technology with: 

■ Active negation of SCSI Data, Parity, 
Request, and Acknowledge signals for 
improved Fast SCSI transfer rates. 

■ Input signal filtering on SCSI receivers; 
improves data integrity, even in noisy 
cabling environments. 
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Chapter 2 

Functional Description 

The SYM53C876 is a multi-function device 
composed of the following modules: 

■ PCI Interface 

■ Two independent PCI-to-Wide Ultra SCSI 
Controllers 

■ ROM/Flash Memory Controller 

■ Serial EEPROM Controller 


Figure 2-1 illustrates the relationship between 
these modules. 

Chapter 2 is divided into the following sections: 

■ PCI Functional Description 

■ SCSI Fimctional Description 

■ Parallel ROM Interface 

■ Serial EEPROM Interface 


PCI Bus 



SCSI Function A 

ROM/Flash 

2-Wire Serial 

2-Wire Serial 

SCSI Function B 

Wide Ultra SCSI 

Memory 

EEPROM Bus 

EEPROM Bus 

Wide Ultra SCSI 

Bus 

Bus 

(Function A) 

(Function B) 

Bus 


Figure 2-1: SYM53C876 Block Diagram 
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PCI Functional Description 

The SYM53C876 implements two PCI-to-Wide 
Ultra SCSI controllers in a single package. This 
configuration presents only one load to the PCI 
bus and uses one REQ/ - GNT/ pair to arbitrate 
for PCI bus mastership. However, separate inter¬ 
rupt signals are generated for SCSI Function A 
and SCSI Function B. 

PCI Addressing 

There are three physical PCI-defined address 
spaces: 

■ Configuration space for SCSI 

■ VO space 

■ Memory space 

Configuration Space 

Two independent sets of configuration space regis¬ 
ters are defined, one set for each SCSI function. 
The Configuration registers are accessible only by 
system BIOS during PCI configuration cycles. 
Each configuration space is a contiguous 256 x 8- 
bit set of addresses. Decoding C_BE/(3-0) deter¬ 
mines if a PCI cycle is intended to access configu¬ 
ration register space. The IDSEL bus signal is a 
“chip select” that allows access to the configura¬ 
tion register space only. A configuration read/write 
cycle without IDSEL is ignored. The eight lower 
order addresses AD (7-0) are used to select a spe¬ 
cific 8-bit register. Since the SYM53C876 is a PCI 
multi-function device, AD (10-8) decodes either 
SCSI Function A Configuration register (AD (10- 
8) = 000 binary) or SCSI Function B Configura¬ 
tion register (AD (10-8) = 001 binary).The host 
processor uses this configuration space to initialize 
the SYM53C876. 

At initialization time, each PCI device is assigned a 
base address (in the case of the SYM53C876, the 
upper 24 bits of the address are selected) for mem¬ 
ory accesses and I/O accesses. On every access, the 
SYM53C876 compares its assigned base addresses 


with the value on the Address/Data bus during the 
PCI address phase. If there is a match of the upper 
24 bits, the access is for the SYM53C876 and the 
low order eight bits define the register to access. A 
decode of C_BE/ (3-0) determines which registers 
and what type of access is performed. 

I/O Space 

PCI defines VO space as a contiguous 32-bit VO 
address that is shared by all system resources, 
including the SYM53C876.The Base Address 
Zero register determines which 256-byte I/O area 
this device occupies. 

Memory Space 

PCI defines memory space as a contiguous 32-bit 
memory address that is shared by all system 
resources, including the SYM53C876.The Base 
Address One register determines which 256-byte 
memory area this device occupies. Each SCSI 
function uses a 4 K SCRIPT RAM memory space. 
The Base Address Two register determines the 4 
KB memory area the SCRIPT RAM occupies. 


PCI Bus Commands and Functions 
Supported 

Bus commands indicate to the target the type of 
transaction the master is requesting. Bus com¬ 
mands are encoded on the C_BE/(3-0) lines dur¬ 
ing the address phase. PCI bus command 
encoding and types appear in Table 2-1. 
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Table 2-1: PCI Bus Commands and Encoding 
Types 


C BE 
(3’0) 

Command Type 

Supported 
as Master 

Supported 
as Slave 

0000 

Interrupt Acknowl¬ 
edge 

No 

No 

0001 

Special Cycle 

No 

No 

0010 

I/O Read 

Yes 

Yes 

0011 

I/O Write 

Yes 

Yes 

0100 

Reserved 

n/a 

n/a 

0101 

Reserved 

n/a 

n/a 

0110 

Memory Read 

Yes 

Yes 

0111 

Memory Write 

Yes 

Yes 

1000 

Reserved 

n/a 

n/a 

1001 

Reserved 

n/a 

n/a 

1010 

Configuration Read 

No 

Yes 

1011 

Configuration Write 

No 

Yes 

1100 

Memory Read Mul¬ 
tiple 

Yes* 

Yes 

(defaults 
to 0110) 

1101 

Dual Address Cycle 

No 

No 

1110 

Memory Read Line 

Yes* 

Yes 

(defaults 
to 0110) 

1111 

Memory Write and 
Invalidate 

Yes** 

Yes 

(defaults 
to 0111) 


* See the DMODE register. 
** See the CTEST3 register 


Interrupt Acknowledge Command 

The SYM53C876 does not respond to this com¬ 
mand as a slave and it never generates this com¬ 
mand as a master. 

Special Cycle Command 

The SYM53C876 does not respond to this com¬ 
mand as a slave and it never generates this com¬ 
mand as a master. 


I/O Read Command 

The I/O Read command is used to read data from 
an agent mapped in I/O address space. All 32 
address bits are decoded. 

I/O Write Command 

The I/O Write command is used to write data to an 
agent mapped in I/O address space. All 32 address 
bits are decoded. 

Reserved Command 

The SYM53C876 does not respond to this com¬ 
mand as a slave and it never generates this com¬ 
mand as a master. 

Memory Read Command 

The Memory Read command is used to read data 
from an agent mapped in the Memory Address 
Space. The target is free to do an anticipatory read 
for this command only if it can guarantee that such 
a read has no side effects. 

Memory Write Command 

The Memory Write command is used to write data 
to an agent mapped in the Memory Address 
Space. When the target returns “ready”, it assumes 
responsibility for the coherency (which includes 
ordering) of the. subject data. 

Configuration Read Command 

The Configuration Read command is used to read 
the configuration space of each agent. An agent is 
selected during a configuration access when its 
IDSEL signal is asserted and AD(1-0) are 00. 
During the address phase of a configuration cycle, 
AD (7-2) address one of the 64 dword registers 
(where byte enables address the bytes within each 
dword) in the configuration space of each device 
and AD(31-11) are logical don’t cares to the 
selected agent. AD (10-8) indicate which device of 
a multi-function agent is being addressed. 
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Configuration Write Command 

The Configuration Write command is used to 
transfer data to the configuration space of each 
agent. An agent is selected when its IDSEL signal 
is asserted and AD (1-0) are 00. During the 
address phase of a configuration cycle, the AD(7- 
2) lines address the 64 dword registers (where byte 
enables address the bytes within each dword) in 
the configuration space of each device, and 
AD(31-11) are logical don’t cares to the selected 
agent. AD (10-8) indicate which device of a multi- 
fimction agent is addressed. 

Memory Read Multiple Command 

This command is identical to the Memory Read 
command except that it additionally indicates that 
the master may intend to fetch more than one 
cache line before disconnecting.The SYM53C876 
supports PCI Read Multiple functionality and 
issues Read Multiple commands on the PCI bus 
when the Read Multiple Mode is enabled. This 
mode is enabled by setting bit 2 of the DMODE 
register (ERMP). If cache mode is enabled, a Read 
Multiple command is issued on all read cycles, 
except op code fetches, when the following condi¬ 
tions are met: 

1. The CLSE bit (Cache Line Size Enable, 
DCNTL, bit 7) and the ERMP bit (Enable 
Read Multiple, DMODE, bit 2) are set. 

2. The Cache Line Size register for each function 
contains a legal burst size value (2,4,8,16,32, 
64, or 128) and that value is less than or equal 
to the DMODE burst size. 

3. The number of bytes to transfer at the time a 
cache boundary is reached is at least twice the 
full cache line size. 

4. The chip is aligned to a cache line boundary. 

When these conditions are met, the chip issues a 
Read Multiple command instead of a Memory 
Read during all PCI read cycles. 


Burst Size Selection 

The Read Multiple command reads in multiple 
cache lines of data in a single bus ownership. The 
number of cache lines to read is a multiple of the 
cache line size as allowed for in Revision 2.1 of the 
PCI specification. The logic selects the largest mul¬ 
tiple of the cache line size based on the amoimt of 
data to transfer, with the maximum allowable burst 
size determined from the DMODE burst size bits, 
and the CTEST5, bit 2. 

Dual Address Cycles Command 

The SYM53C876 does not respond to this com¬ 
mand as a slave and it never generates this com¬ 
mand as a master. 

Memory Read Line Command 

This command is identical to the Memory Read 
command, except that it additionally indicates that 
the master intends to fetch a complete cache line. 
This command is intended for use with bulk 
sequential data transfers where the memory system 
and the requesting master might gain some perfor¬ 
mance advantage by reading up to a cache line 
boundary rather than a single memory cycle. The 
Read Line function that exists in the previous 
SYM53C8XX chips is modified in the 
SYM53C876 to reflect the PCI Cache Line Size 
register specifications. The functionality of the 
Enable Read Line bit (DMODE register, bit 3) is 
modified to more resemble the Write and Invali¬ 
date mode in terms of conditions that must be met 
before a Read Line command is issued. However, 
the Read Line option operates exactly like the pre¬ 
vious SYM53C8XX chips when cache mode is 
disabled by a CLSE bit reset or when certain con¬ 
ditions exist in the chip (explained below). 

If cache mode is disabled. Read Line commands 
are issued on every read data transfer, except op 
code fetches, as in previous SYM53C8XX chips. 

If cache mode is enabled, a Read line command is 
issued on all read cycles, except op code fetches, 
when the following conditions are met: 
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1. The CLSE (Cache Line Size Enable, 

DCNTL, bit 7) and ERL (Enable Read Line, 
DMODE, bit 3) bits are set. 

2. The Cache Line Size register for each function 
must contain a legal burst size value (2,4,8, 

16, 32, 64, or 128) and that value is less than 
or equal to the DMODE burst size. 

3. The number of bytes to transferred at the time 
a cache boundary is reached is equal to or 
greater than the DMODE burst size. 

4. The chip is aligned to a cache line boundary. 

When these conditions are met, the chip issues a 
Read Line command instead of a Memory Read 
during all PCI read cycles. Otherwise, it issues a 
normal Memory Read command. 

Read Multiple with Read Line Enabled 
When both the Read Multiple and Read Line 
modes are enabled, the Read Line command is not 
issued if the above conditions are met. Instead, a 
Read Multiple command is issued, even though 
the conditions for Read Line are met. 

If the Read Multiple mode is enabled and the Read 
Line mode is disabled. Read Multiple commands 
are issued if the Read Multiple conditions are met. 

Memory Write and Invalidate Command 

The Memory Write and Invalidate command is 
identical to the Memory Write command, except 
that it additionally guarantees a minimum transfer 
of one complete cache linej that is to say, the mas¬ 
ter intends to write all bytes within the addressed 
cache line in a single PCI transaction unless inter¬ 
rupted by the target. This command requires 
implementation of the PCI Cache Line Size regis¬ 
ter at address OCh in PCI configuration space.The 
SYM53C876 enables Memory Write and Invali¬ 
date cycles when bit 0 in the CTEST3 register 
(WRIE) and bit 4 in the PCI Command register 
(WIE) are set. When the following conditions are 
met. Memory Write and Invalidate commands are 
issued: 


1. The CLSE bit (Cache Line Size Enable, 
DCNTL, bit 7), WRIE bit (Write and Invalid 
Enable, CTEST3, bit 0), and PCI 
configuration Command register, bit 4 are set. 

2. The Cache Line Size register for each function 
contains a legal burst size value (2,4,8,16,32, 
64, or 128) and that value is less than or equal 
to the DMODE burst size. 

3. The chip has enough bytes in the DMA FIFO 
to complete at least one full cache line burst. 

4. The chip is aligned to a cache line boimdary. 

When these conditions are met, the SYM53C876 
issues a Write and Invalidate command instead of a 
Memory Write command during all PCI write 
cycles. 

Multiple Cache Line Transfers 
The Write and Invalidate command can write mul¬ 
tiple cache lines of data in a single bus ownership. 
The chip issues a burst transfer as soon as it 
reaches a cache line boundary. The size of the 
transfer is not automatically the cache line size, but 
rather a multiple of the cache line size as allowed 
for in Revision 2.1 of the PCI specification. The 
logic selects the largest multiple of the cache line 
size based on the amount of data to transfer, with 
the maximum allowable burst size determined 
from the DMODE burst size bits, and CTEST5, 
bit 2. If multiple cache line size transfers are not 
desired, set the DMODE burst size to exactly the 
cache line size and the chip only issues single cache 
line transfers. 

After each data transfer, the chip re-evaluates the 
burst size based on the amount of remaining data 
to transfer and again selects the highest possible 
multiple of the cache line size, no larger than the 
DMODE burst size. The most likely scenario of 
this scheme is that the chip selects the DMODE 
burst size after alignment, and issues bursts of this 
size. The burst size is, in effect, throttled down 
toward the end of a long Memory Move or Block 
Move transfer until only the cache line size burst 
size is left. The chip finishes the transfer with this 
burst size. 
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Latency 

In accordance with the PCI specification, the 
chip's latency timer is ignored when issuing a Write 
and Invalidate command such that when a latency 
time-out occurs, the SYM53C876 continues to 
transfer up to a cache line boimdary. At that point, 
the chip relinquishes the bus, and finishes the 
transfer at a later time using another bus owner¬ 
ship. If the chip is transferring multiple cache lines 
it continues to transfer until the next cache bound¬ 
ary is reached. 

PCI Target Retry 

During a Write and Invalidate transfer, if the target 
device issues a retry (STOP with no TRDY, indi¬ 
cating that no data was transferred), the chip relin¬ 
quishes the bus and immediately tries to finish the 
transfer on another bus ownership. The chip issues 
anotherWrite and Invalidate command on the next 
ownership, in accordance with the PCI specifica¬ 
tion. 

PCI Target Disconnect 

During a Write and Invalidate transfer, if the target 
device issues a disconnect the SYM53C876 relin¬ 
quishes the bus and immediately tries to finish the 
transfer on another bus ownership. The chip does 
not issue anotherWrite and Invalidate command 
on the next ownership unless the address is 
aligned. 


Internal Arbiter 

The PCI-SCSI controller uses a single REQ/ - 
GNT/ signal pair to arbitrate for access to the PCI 
bus. An internal arbiter circuit allows the different 
bus-mastering functions resident in the chip to 
arbitrate among themselves for the privilege of 
arbitrating for PCI bus access. There are two inde¬ 
pendent bus-mastering functions inside the 
SYM53C876, one for each of the SCSI functions. 
Each SCSI function has a register which allows 
programming of a three-bit arbitration priority 
level. Zero is the lowest priority, and seven is the 
highest priority. 

The internal arbiter uses the arbitration priority 
levels to decide which internal bus-mastering func¬ 
tion may arbitrate for access to the PCI bus. If two 


functions request access to the PCI bus simulta¬ 
neously, the function with the higher arbitration 
priority level is granted access first. The internal 
arbiter implements a fairness algorithm (Function 
A level - Fimction B level + one) to insure that no 
function gets starved for access to the PCI bus due 
to activity on other functions with higher arbitra¬ 
tion priority levels. The difference between the pri¬ 
ority levels, along with the SCSI function burst 
size, determines the percentage of bandwidth allo¬ 
cated to each back-end function. 

For example, if SCSI Function A has priority level 
three, and SCSI Function B has level one, then 
SCSI Function A is allowed to transmit or receive 
three bursts of data over the PCI bus for every one 
burst of data that SCSI Function B transmits. 
Changing the burst size for a particular SCSI func¬ 
tion also alters the bandwidth percentage. 

If arbitration priority levels for both SCSI func¬ 
tions are set to the same value, then the arbitration 
algorithm defaults to a round-robin arbitration 
scheme. 


PCI Cache Mode 

The SYM53C876 supports the PCI specification 
for an 8-bit Cache Line Size register located in 
PCI configuration space. The Cache Line Size reg¬ 
ister provides the ability to sense and react to non- 
aligned addresses corresponding to cache line 
boundaries. In conjunction with the Cache Line 
Size register, the PCI commands Read Line, Read 
Multiple, and Write and Invalidate are each soft¬ 
ware enabled or disabled to allow the user full flex¬ 
ibility in using these commands. 

Selection of Cache Line Size 

The cache logic for each bus mastering function 
selects a cache line size based on the values for the 
burst size in the DMODE register, and the PCI 
Cache Line Size register, whichever is appropriate. 

Note: Each bus mastering function does not 
automatically use the value in its PCI 
Cache Line Size register as the cache line 
size value. The chip scales the value of the 
Cache Line Size register down to the 
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nearest binary burst size allowed by the 
chip (2j 4j 8j 16j 32, 64, or 128).The SCSI 
function compares this value to the 
DMODE burst size, then selects the 
smaller as the value for the cache line size. 

Alignment 

The SYM53C876 uses the calculated line size 
value to monitor the current address for alignment 
to the cache line size. When it is not aligned, the 
chip attempts to align to the cache boundary by 
using a “smart aligning” scheme. This means that 
it attempts to use the largest burst size possible 
that is less than the cache line size, to reach the 
cache boundary quickly with no overflow. This 
process is a stepping mechanism that steps up to 
the highest possible burst size based on the current 
address. 

The stepping process begins at a 4-dword bound¬ 
ary. The SYM53C876 first tries to align to a 4- 
dword boundary (0x0000, 0x0010, 0x0020, etc.) 
by using single dword transfers (no bursting). 
Once this boundary is reached the chip evaluates 
the current alignment to various burst sizes 
allowed, and selects the largest possible as the next 
burst size, while not exceeding the cache line size. 
The chip then issues this burst, and re-evaluates 
the alignment to various burst sizes, again selecting 
the largest possible while not exceeding the cache 
line size, as the next burst size. This stepping pro¬ 
cess continues imtil the chip reaches the cache line 
size boundary or runs out of data. Once a cache 
line boundary is reached, the chip uses the cache 
line size as the burst size from then on, except in 
the case of multiples (explained below). The align¬ 
ment process is finished at this point. 


aligned not only to a 4-dword boundary, but also 
to an 8-dword boundary. It selects the highest, 8, 
and bursts 8 dwords. At this point, the address is 
0x40h, which is a cache line size boundary. Align¬ 
ment stops, and the burst size from then on is 
switched to 16. 

Memory Move IVlisalignment 

The SYM53C876 does not operate in a cache 
alignment mode when a Memory Move instruc¬ 
tion type is issued and the read and write addresses 
are different distances from the nearest cache line 
boundary. For example, if the read address is 
0x2IF and the write address is 0x42F, and the 
cache line size is eight (8), the addresses are byte 
aligned, but they are not the same distance from 
the nearest cache boundary. The read address is 1 
byte from the cache boundary 0x220 and the write 
address is 17 bytes from the cache boundary 
0x440. In this situation, the chip does not align to 
cache boimdaries. 


Example: Cache Line Size = 16, 

Current Address = 0x0 Ih 
The chip is not aligned to a 4-dword cache bound¬ 
ary (the stepping threshold), so it issues four sin- 
gle-dword transfers (the first is a 3-byte transfer). 
At address 0x10, the chip is aligned to a 4-dword 
boundary, but not aligned to any higher burst size 
boundaries that are less than the cache line size. 
So, the part issues a burst of 4. At this point, the 
address is 0x20, and the chip evaluates that it is 
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Two SCSI Controllers 

The SYM53C876 provides two SCSI controllers 
on a single chip. Each SCSI controller provides a 
SCSI function that supports an 8-bit or 16-bit bus. 
Each supports Wide Ultra SCSI synchronous 
transfer rates up to 40 MB/s, Ultra SCSI synchro¬ 
nous transfer rates up to 20 MB/s, and asynchro¬ 
nous transfer rates up to 14 MB/s on a wide SCSI 
bus. The SCSI functions are programmed with 
SCSI SCRIPTS, making it easy to “fine time” the 
system for specific mass storage devices or SCSI-2 
requirements. 

The SYM53C876 offers low-level register access 
or a high-level control interface. Like first genera¬ 
tion SCSI devices, the SYM53C876 is accessed as 
a register-oriented device. The ability to sample 
and/or assert any signal on the SCSI bus is used in 
error recovery and diagnostic procedures. In sup¬ 
port of SCSI loopback diagnostics, each SCSI 
function may perform a self-selection and operate 
as both an initiator and a target. 

The SYM53C876 is controlled by the integrated 
SCRIPTS processor through a high-level logical 
interface. Commands controlling the SCSI func¬ 
tions are fetched out of the main host memory or 
local memory. These commands instruct the SCSI 
functions to Select, Reselect, Disconnect, Wait for 
a Disconnect, Transfer Information, Change Bus 
Phases and, in general, implement all aspects of 
the SCSI protocol. The SCRIPTS processor is a 
special high-speed processor optimized for SCSI 
protocol. 

SCRIPTS Processor 

The SCSI SCRIPTS processor allows both DMA 
and SCSI commands to be fetched from host 
memory or internal SCRIPTS RAM. Algorithms 
written in SCSI SCRIPTS control the actions of 


the SCSI and DMA cores. The SCRIPTS proces¬ 
sor executes complex SCSI bus sequences inde¬ 
pendently of the host CPU. 

Algorithms may be designed to tune SCSI bus per¬ 
formance, to adjust to new bus device types (such 
as scanners, communication gateways, etc.), or to 
incorporate changes in the SCSI-2 or SCSI-3 logi¬ 
cal bus definitions without sacrificing I/O perfor¬ 
mance. SCSI SCRIPTS are hardware- 
independent, so they can be used interchangeably 
on any host or CPU system bus. 

Internal SCRIPTS RAM 

The SYM53C876 has 4 KB (1024 x 32 bits) of 
internal, general purpose RAM for each SCSI 
function. The RAM is designed for SCRIPTS pro¬ 
gram storage, but is not limited to this type of 
information. When the chip fetches SCRIPTS 
instructions or Table Indirect information firom the 
internal RAM, these fetches remain internal to the 
chip and do not use the PCI bus. Other types of 
access to the RAM by the chip use the PCI bus, as 
if they were external accesses. The MADS pin dis¬ 
ables the 4 K internal RAM. To disable the inter¬ 
nal RAM, connect a 4.7K Q resistor between the 
MADS pin andVss (ground) The SCRIPTS RAM 
by default powers-up enabled. 

The RAM can be relocated by the PCI system 
BIOS anywhere in 32-bit address space. The Base 
Address Two register in PCI configuration space 
contains the base address of the internal RAM. 
This register is similar to the ROM Base Address 
register in PCI configuration space. To simplify 
loading of SCRIPTS instructions, the base address 
of the RAM appears in the SCRATCHB register 
when bit 3 of the CTEST2 register is set. The 
RAM is byte-accessible firom the PCI bus and is 
visible to any bus-mastering device on the bus. 
External accesses to the RAM (by the CPU) follow 
the same timing sequence as a standard slave regis¬ 
ter access, except that the target wait states 
required drops from 5 to 3. 
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A complete set of development tools is available for 
writing custom drivers with SCSI SCRIPTS. For 
more information on the SCSI SCRIPTS instruc¬ 
tions supported by the SYM53C876, see Chapter 
5. 

Prefetching SCRIPTS Instructions 

When enabled by setting the Prefetch Enable bit 
(bit 5) in the DCNTL register, the prefetch logic 
in the SYM53C876 fetches 8 dwords of instruc¬ 
tions. The prefetch logic automatically determines 
the maximum burst size that it can perform, based 
on the burst length as determined by the values in 
the DMODE register. If the unit cannot perform 
bursts of at least four dwords, it disables itself. 
While the chip is prefetching SCRIPTS instruc¬ 
tions, the PCI Cache Line Size register value does 
not have any effect and the Read Line, Read Mul¬ 
tiple, and Write and Invalidate commands are not 
used. 

Note: This feature is only useful if fetching 

SCRIPTS instructions from main memory. 
Due to the short access time of SCRIPTS 
RAM, prefetching is not necessary when 
fetching instructions from this memory. 

The SYM53C876 may flush the contents of the 
prefetch imit under certain conditions, listed 
below, to ensure that the chip always operates from 
the most current version of the SCRIPTS instruc¬ 
tion. When one of these conditions apply, the con¬ 
tents of the prefetch unit are flushed automatically. 

1. On every Memory Move instruction. The 
Memory Move instruction is often used to 
place modified code directly into memory. To 
make sure that the chip executes all recent 
modifications, the prefetch unit flushes its 
contents and loads the modified code every 
time a instruction is issued. To avoid 
inadvertently flushing the prefetch unit 
contents, use the No Flush option for all 
Memory Move operations that do not modify 
code within the next 8 dwords. For more 
information on this instruction, refer to 
Chapter 5. 
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2. On every Store instruction. The Store 
instruction may also be used to place modified 
code directly into memory. To avoid 
inadvertently flushing the prefetch imit 
contents, use the No Flush option for all Store 
operations that do not modify code within the 
next 8 dwords. 

3. On every write to the DSP. 

4. On all Transfer Control instructions when the 
transfer conditions are met. This is necessary 
because the next instruction to execute is not 
the sequential next instruction in the prefetch 
unit. 

5. When the Prefetch Flush bit (DCNTL bit 6) is 
set. The unit flushes whenever this bit is set. 
The bit is self-clearing. 

Op Code Fetch Burst Capability 

Setting the Burst Op Code Fetch Enable bit (bit 1) 
in the DMODE register (38h) causes the 
SYM53C876 to burst in the first two dwords of all 
instruction fetches. If the instruction is a memory- 
to-memory move, the third dword is accessed in a 
separate ownership. If the instruction is an indirect 
type, the additional dword is accessed in a subse¬ 
quent bus ownership. If the instruction is a table 
indirect Block Move, the chip uses two accesses to 
obtain the four dwords required, in two bursts of 
two dwords each. 

Note: This feature is only useful if Prefetching is 
disabled. 

Note: This feature is only useful if fetching 

SCRIPTS instructions from main memory. 
Due to the short access time of SCRIPTS 
RAM, burst op code fetching is not 
necessary when fetching instructions from 
this memory. 

Load/Store Instructions 

The SYM53C876 supports the Load/Store 
instruction type, which simplifies the movement of 
data between memory and the internal chip regis- 
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ters. It also enables the chip to transfer bytes to 
addresses relative to the DSA register. For more 
information on the Load and Store instructionsj 
refer to Chapter 5. 


JTAG Boundary Scan Testing 

The SYM53C876 includes support for JTAG 
boundary scan testing in accordance with the 
IEEE 1149.1 specification, with one exception 
which is explained in this section. This device 
accepts all required boundary scan instructions, 
including the optional CLAMP, HIGHZ, and 
ID CODE instructions. 

The SYM53C876 uses an 8-bit instruction regis¬ 
ter to support all boimdary scan instructions. The 
data registers included in the device are the 
Boundary Data register, the ID CODE register, 
and the Bypass register. This device can handle a 
10 MHzTCK frequency forTDO andTDI. 

Due to design constraints, the RST/ pin (system 
reset) always tri-states the SCSI pins when it is 
asserted. Boundary scan logic does not control this 
action, and this is not compliant with the specifica¬ 
tion. There are two solutions that resolve this issue: 

1. Use the RST/ pin as a boundary scan 

compliance pin. When the pin is deasserted, 
the device is boimdary scan compliant and 
when asserted, the device is non-compliant.To 
maintain compliance, the RST/ pin must be 
driven high. 


SCSI Loopback Mode 

The SYM53C876 loopback mode allows testing of 
both initiator and target functions and, in effect, 
lets the chip communicate with itself. When the 
Loopback Enable bit is set in the STEST2 register, 
bit 4, the SYM53C876 allows control of all SCSI 
signals, whether the chip is operating in initiator or 
target mode. For more information on this mode 
of operation, refer to the SYM53C8XX Family Pro¬ 
gramming Guide. 

Parity Options 

The SYM53C876 implements a flexible parity 
scheme that allows control of the parity sense, 
allows parity checking to be turned on or off, and 
has the ability to deliberately send a byte with bad 
parity over the SCSI bus to test parity error recov¬ 
ery procedures. Table 2-4 defines the bits that are 
involved in parity control and observation. Table 2- 
5 describes the parity control function of the 
Enable Parity Checking and Assert SCSI Even 
Parity bits in the SCNTLl register, bit 2. Table 2-6 
describes the options available when a parity error 
occurs. Figure 2-2 shows where parity checking is 
done in the SYM53C876. 


2. When RST/ is asserted during boundary scan 
testing, the expected output on the SCSI pins 
must be the high-z condition, and not what is 
contained in the boundary scan data registers 
for the SCSI pin output cells. 
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Table 2-2: Bits Used for Parity Control and Generation 


Bit Name 

Location 

Description 

Assert SATN/ on 
Parity Errors 

SCNTLO, Bit 1 

Causes the 53C876 to automatically assert SATN/ when it 
detects a SCSI parity error while operating as an initiator. 

Enable Parity 
Checking 

SCNTLO, Bit 3 

Enables the 53C876 to check for parity errors. The 53C876 
checks for odd parity. 

Assert Even SCSI 
Parity 

SCNTLl,Bit2 

Determines the SCSI parity sense generated by the 53C876 to 
the SCSI bus. 

Disable Halt on 
SATN/ or a Parity 
Error (Target Mode 
Only) 

SCNTLljBitS 

Causes the 53C876 not to halt operations when a parity error is 
detected in target mode. 

Enable Parity Error 
Interrupt 

SIENO, Bit 0 

Determines whether the 53C876 generates an interrupt when it 
detects a SCSI parity error. 

Parity Error 

SISTO, Bit 0 

This status bit is set whenever the 53C876 detects a parity error 
on the SCSI bus. 

Status of SCSI 

Parity Signal 

SSTATO, Bit 0 

This status bit represents the active high current state of the 

SCSI SDPO parity signal. 

SCSI SDPl Signal 

SSTAT2, Bit 0 

This bit represents the active high current state of the SCSI 

SDPl parity signal. 

Latched SCSI Parity 

SSTAT2, Bit 3 and 
SSTATl,Bit3 

These bits reflect the SCSI odd parity signal corresponding to 
the data latched into the SIDL register 

Master Parity Error 
Enable 

CTEST4, Bit 3 

Enables parity checking during PCI master data phases. 

Master Data Parity 
Error 

DSTAT, Bit 6 

Set when the 53C876, as a PCI master, detects a target device 
signaling a parity error during a data phase. 

Master Data Parity 
Error Interrupt 

Enable 

DIEN, Bit 6 

By clearing this bit, a Master Data Parity Error does not cause 
assertion of INTA/ (or INTB/), but the status bit is set in the 
DSTAT register. 
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Table 2-3: SCSI Parity Control 



EPC 

ASEP 

Description 

0 

0 


Does not check for parity errors. Parity is generated when sending SCSI data. 
Asserts odd parity when sending SCSI data. 

0 

1 


Does not check for parity errors. Parity is generated when sending SCSI data. 
Asserts even parity when sending SCSI data. 

1 

0 


Checks for odd parity on SCSI data received. Parity is generated when sending 
SCSI data. Asserts odd parity when sending SCSI data. 

1 

1 


Checks for odd parity on SCSI data received. Parity is generated when sending 
SCSI data. Asserts even parity when sending SCSI data. 

Key: EPC - Enable Parity Checking (bit 3 SCNTLO);ASEP = Assert SCSI Even Parity (bit 2 SCNTLl) 

Table 2-4: SCSI Parity Errors and Interrupts 


DHP 

PAR 

Description 

0 

0 


Halts when a parity error occurs in target or initiator mode and does NOT gen¬ 
erate an interrupt. 

0 

1 


Halts when a parity error occurs in target mode and generates an interrupt in 
target or initiator mode. 

1 

0 


Does not halt in target mode when a parity error occurs until the end of the 
transfer. An interrupt is not generated. 

1 

1 


Does not halt in target mode when a parity error occurs until the end of the 
transfer. An interrupt is generated. 

Key: DHP — Disable Halt on SATNI or Parity Error (bit 5 SCNTLl); PAR — Parity Error (bit 0 SIENO) 
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Figure 2-2: Parity Checking/Generation 


DMA FIFO 

The DMA FIFO is 4 bytes wide by 134 transfers 
deep. The DMA FIFO is illustrated in Figure 2-3. 
The default DMA FIFO size is 88 bytes to assure 
compatibility with older products in the 
SYM53C8XX family; the user may set the DMA 
FIFO size to 536 bytes by setting the DMA FIFO 
Size bit, bit 5 in the CTEST5 register. 
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Figure 2-3: DMA FIFO Sections 


The SYM53C876 supports 32-bit memory and 
automatically supports misaligned DMA transfers. 
A 536-byte FIFO allows the 53C876 to support 2, 
4, 8j 16, 32, 64, or 128 dword bursts across the 
PCI bus interface. 

Data Paths 

The data path through the SYM53C876 is depen¬ 
dent on whether data is being moved into or out of 
the chip, and whether SCSI data is being trans¬ 
ferred asynchronously or synchronously. 

Figure 2-4 shows how data is moved to/from the 
SCSI bus in each of the different modes. 

The following steps determine if any bytes remain 
in the data path when the chip halts an operation: 

Asynchronous SCSI Send 

1. If the DMA FIFO size is set to 88 bytes, look 
at the DFIFO and DBC registers and calculate 
if there are bytes left in the DMA FIFO. To 
make this calculation, subtract the seven least 
significant bits of the DBC register from the 7- 
bit value of the DFIFO register. AND the 
result with 7Fh for a byte coimt between zero 


SYM53C876 Data Manual 


2-13 

























Functional Description PRELIMINARY 

SCSI Functional Description 


and 88. 

If the DMA FIFO size is set to 536 bytes 
(using bit 5 of the CTEST5 register), subtract 
the 10 least significant bits of the DBG register 
from the 10-bit value of the DMA FIFO Byte 
Offset Counter, which consists of bits 1-0 in 
the CTEST5 register and bits 7-0 of the DMA 
FIFO register. AND the result with 3FFh for a 
byte count between 0 and 536. 

2. Read bit 5 in the SSTATO and SSTAT2 

registers to determine if any bytes are left in the 
SODL register. If bit 5 is set in the SSTATO or 
SSTAT2, then the least significant byte or the 
most significant byte in the SODL register is 
full, respectively. Checking this bit also reveals 
bytes left in the SODL register from a Chained 
Move operation with an odd byte count. 

Synchronous SCSI Send 

1. If the DMA FIFO size is set to 88 bytes, look 
at the DFIFO and DBC registers and calculate 
if there are bytes left in the DMA FIFO. To 
make this calculation, subtract the seven least 
significant bits of the DBC register from the 7- 
bit value of the DFIFO register. AND the 
result with 7Fh for a byte count between zero 
and 88. 

If the DMA FIFO size is set to 536 bytes 
(using bit 5 of the CTEST5 register), subtract 
the 10 least significant bits of the DBC register 
from the 10-bit value of the DMA FIFO Byte 
Offset Counter, which consists of bits 1-0 in 
the CTEST5 register and bits 7-0 of the DMA 
FIFO register. AND the result with 3FFh for a 
byte coimt between 0 and 536. 

2. Read bit 5 in the SSTATO and SSTAT2 
registers to determine if any bytes are left in the 
SODL register. If bit 5 is set in the SSTATO or 
SSTAT2, then the least significant byte or the 
most significant byte in the SODL register is 
full, respectively. Checking this bit also reveals 
bytes left in the SODL register from a Chained 
Move operation with an odd byte count. 

3. Read bit 6 in the SSTATO and SSTAT2 


registers to determine if any bytes are left in the 
SODR register. If bit 6 is set in the SSTATO or 
SSTAT2, then the least significant byte or the 
most significant byte in the SODR register is 
full, respectively. 

Asynchronous SCSI Receive 

1. If the DMA FIFO size is set to 88 bytes, look 
at the DFIFO and DBC registers and calculate 
if there are bytes left in the DMA FIFO. To 
make this calculation, subtract the seven least 
significant bits of the DBC register from the 7- 
bit value of the DFIFO register. AND the 
result with 7Fh for a byte count between 0 and 
88 . 

If the DMA FIFO size is set to 536 bytes 
(using bit 5 of the CTEST5 register), subtract 
the 10 least significant bits of the DBC register 
from the 10-bit value of the DMA FIFO Byte 
Offset Counter, which consists of bits 1-0 in 
the CTEST5 register and bits 7-0 of the DMA 
FIFO register. AND the result with 3FFh for a 
byte count between 0 and 536. 

2. Read bit 7 in the SSTATO and SSTAT2 
register to determine if any bytes are left in the 
SIDL register. If bit 7 is set in the SSTATO or 
SSTAT2, then the least significant byte or the 
most significant byte is full, respectively. 

3. If any wide transfers have been performed 
using the Chained Move instruction, read the 
Wide SCSI Receive bit (SCNTL2, bit 0) to 
determine whether a byte is left in the SWIDE 
register. 
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Synchronous SCSI Receive 

1. If the DMA FIFO size is set to 88 bytes, 
subtract the seven least significant bits of the 
DBG register from the 7-bit value of the 
DFIFO register. AND the result with 7Fh for a 
byte count between 0 and 88. 

If the DMA FIFO size is set to 536 bytes 
(using bit 5 of the CTEST5 register), subtract 
the 10 least significant bits of the DBG register 
from the 10-bit value of the DMA FIFO Byte 
Offset Counter, which consists of bits 1-0 in 
the CTEST5 register and bits 7-0 of the DMA 
FIFO register. AND the result with 3FFh for a 


byte count between 0 and 536. 

2. Read the SSTATl register and examine bits 7- 
4, the binary representation of the number of 
valid bytes in the SCSI FIFO, to determine if 
any bytes are left in the SCSI FIFO. 

3. If any wide transfers have been performed 
using the Chained Move instruction, read the 
Wide SCSI Receive bit (SCNTL2, bit 0) to 
determine whether a byte is left in the SWIDE 
register. 



Figure 2-4: SYM53C876 Host Interface SCSI Data Paths 


SCSI Bus Interface 

All SCSI signals are active low. The SYM53C876 
contains the single-ended output drivers and can 
be connected directly to the SCSI bus. Each out¬ 
put is isolated from the power supply to ensure 
that a powered-down SYM53C876 has no effect 
on an active SCSI bus (CMOS “voltage feed¬ 
through” phenomena).TolerANT technology pro¬ 
vides signal filtering at the inputs of SREQ/ and 
SACK/ to increase immunity to signal reflections. 


Differential Mode 

In differential mode, the SDIR (15-0), 

SDIRPO/1, IGS,TGS, RSTDIR, BSYDIR, and 
SELDIR signals control the direction of external 
differential-pair transceivers. The SYM53C876 is 
placed in differential mode by setting the DIF bit, 
bit 5 of the STEST2 register (4Eh). Setting this bit 
tri-states the BSY/, SEL/, and RST/ pads so they 
can be used as pure input pins. In addition to the 
standard SCSI lines, the following signals are used 
during differential operation by the SYM53C876: 
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Signal 

Function 

BSYDIR, SELDIR, 

RSTDIR 

Active high signals used to enable the differential drivers as outputs for SCSI signals BSY/, 
SEL/, and RST/, respectively 

SDIR(15-0), 

SDIRP(0/1) 

Active high signals used to control direction of the differential drivers for SCSI data and par¬ 
ity lines, respectively 

IGS 

Active high signal used to control direction of the differential driver for initiator group sig¬ 
nals ATN/and ACK/ 

TGS 

Active high signal used to control direction of the differential drivers for target group signals 
MSG/, C/D/, FO/, and REQ/ 

DIFFSENS 

Input to the SYM53C876 used to detect the presence of a single-ended device on a differ¬ 
ential system. If a logical zero is detected on this pin, then it is assumed that a single-ended 
device is on the bus and all SCSI outputs are tri-stated to avoid damage to the transceiver. 


See Figure 2-5 for an example differential wiring 
diagram, in which the SYM53C876 is connected 
to theTI SN75976A differential transceiver. The 
recommended value of the pull-up resistor on the 
REQ/, ACK/, MSG/, C/D/, I/O/, ATN/, SDO-15/, 
SDPO/, and SDPl/ lines is 680 when the Active 
Negation portion of Symbios Logic TolerANT 
technology is not enabled. When TolerANT is 
enabled, the recommended resistor value on the 
REQ/, ACK/, SD7-0/, and SDPO/ signals is 1.5 
KD. The electrical characteristics of these pins 
change when TolerANT is enabled, permitting a 
higher resistor value. 

To interface the SYM53C876 to the SN75976A, 
connect the DIR pins, as well as IGS and TGS, of 
the SYM53C876 directly to the transceiver 
enables (nDE/RE/).These signals control the 
direction of the channels on the SN75976A. 

The SCSI bi-directional control and data pins 
(SD15-0/, SDPO/, SDPl/, REQ/, ACK/, MSG/, 
I_0/, C_D/, and ATN/) of the SYM53C876 con¬ 
nect to the bi-directional data pins (nA) of the 
SN75976A with a pull-up resistor. The three 
remaining pins, SEIV, BSY/, and RST/ are con¬ 
nected to the SN75976A with a pull-down resistor. 
The pull-down resistors are required when the pins 
(nA) of the SN75976A are configured as inputs. 
When the data pins are inputs, the resistors pro¬ 
vide a bias voltage to both the SYM53C876 pins 
(SEL/, BSY/, and RST/) and the SN75976A data 


pins. Because the SEL/, BSY/, and RST/ pins on 
the SYM53C876 are inputs only, this configura¬ 
tion allows for the SEL/, BSY/, and RST/ SCSI 
signals to be asserted on the SCSI bus. The differ¬ 
ential pairs on the SCSI bus are reversed when 
connected to the SN75976A, due to the active low 
nature of the SCSI bus. 

The pull-up value should be no lower than the 
transceiver Iql can tolerate, but not so high as to 
cause RC timing problems. 

Note: Use the TISN75976A differential 

transceivers to achieve Ultra SCSI transfer 
rates. 

8-bit/l6-bit SCSI and the Differential 
Interface 

In an 8-bit SCSI bus, the SD15-8 pins on the 
SYM53C876 should be pulled up with a 1.5 KD 
resistor or terminated like the rest of the SCSI bus 
lines. This is very important, as errors may occur 
during reselection if these lines are left floating. 
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Figure 2-5: SYM53C876 Dififerential Wiring Diagram 
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Terminator Networks 

The terminator networks provide the biasing 
needed to pull signals to an inactive voltage level, 
and to match the impedance seen at the end of the 
cable with the characteristic impedance of the 
cable. Install terminators at the extreme ends of 
the SCSI chain, and only at the ends; no system 
should ever have more or less than two terminators 
installed and active. SCSI host adapters should 
provide a means of accommodating terminators. 
The terminators should be socketed, so that if not 
needed they may be removed, or there should be a 
means of disabling them with software. 

Single-ended cables can use a 220 Cl pull-up to the 
terminator power supply (Term-Power) line and a 
330 Cl pull-down to Ground. Because of the high- 
performance nature of the SYM53C876, Regu¬ 
lated (or Active) termination is recommended. 
Figure 2-6 shows a Unitrode™ active terminator. 
For additional information, refer to the SCSI-2 
Specification. TolerANT active negation is com¬ 
patible with either termination network. 

Note: If the SYM53C876 is used in a design with 
only an 8-bit SCSI bus, all 16 data lines 
still must be terminated or pulled high. 

Note: Active termination is required for Wide 
Ultra SCSI synchronous transfers. 
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Figure 2-6: Regulated Termination 
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Synchronous Operation 

The SYM53C876 can transfer synchronous SCSI 
data in both initiator and target modes. The 
SXFER register controls both the synchronous off¬ 
set and the transfer period. It may be loaded by the 
CPU before SCRIPTS execution begins, from 
within SCRIPTS via a Table Indirect I/O instruc¬ 
tion, or with a Read-Modify-Write instruction. 

The SYM53C876 can receive data from the SCSI 
bus at a synchronous transfer period as short as 50 
ns, regardless of the transfer period used to send 
data. The chip can receive data at one-fourth of the 
divided SCLK frequency. Depending on the 
SCLK frequency, the negotiated transfer period, 
and the synchronous clock divider, the chip can 
send synchronous data at intervals as short as 50 
ns for Wide Ultra SCSI, 100 ns for Fast SCSI and 
200 ns for SCSI-1. 

Determining the Data Transfer Rate 

Synchronous data transfer rates are controlled by 
bits in two different registers of the SYM53C876. 
A brief description of the bits is provided below. 
Figure 2-7 illustrates the clock division factors 
used in each register, and the role of the register 
bits in determining the transfer rate. 

SCNTL3 Register, bits 6-4 (SCF2-0) 

The SCF2-0 bits select the factor by which the fre¬ 
quency of SCLK is divided before being presented 
to the synchronous SCSI control logic. The output 
from this divider controls the rate at which data 
can be received; this rate must not exceed 80 
MHz. The receive rate is 1/4 of the divider output. 

SCNTL3 Register, bits 2-0 (CCF2-0) 

The CCF2-0 bits select the factor by which the 
frequency of SCLK is divided before being pre¬ 
sented to the asynchronous SCSI controller logic. 
This divider must be set according to the input 
clock frequency in the table. 


SXFER Register, bits 7-5 (TP2-0) 

TheTP2-0 bits determine the SCSI synchronous 
transfer period when sending synchronous SCSI 
data in either initiator or target mode. 

Wide Ultra SCSI Synchronous Transfers 

Wide Ultra SCSI is simply an extension of current 
Fast SCSI synchronous transfer specifications. It 
allows synchronous transfer periods to be negoti¬ 
ated down as low as 50 ns, which is half the 100 ns 
period allowed under Fast SCSI. This allows a 
maximum transfer rate of 40 MB/s on a 16-bit 
SCSI bus. The SYM53C876 requires that the 40 
MHz clock is doubled by the internal clock dou¬ 
bler (see the STESTl register description) to per¬ 
form Wide Ultra SCSI transfers. In addition, the 
following bit values affect the chip’s ability to sup¬ 
port Wide Ultra SCSI synchronous transfer rates: 

1. Clock Conversion Factor bits, SCNTL3 
register bits 2-0 and Synchronous Clock 
Conversion Factor bits, SCNTL3 register bits 
6-4. These fields now support a value of 101 
(binary), allowing the SCLK frequency to be 
divided down by 4. This allows systems with a 
40 MHz clock to operate at Fast SCSI-2 
transfer rates as well as Wide Ultra SCSI rates, 
if needed. 

2. Wide Ultra SCSI Mode Enable bit, SCNTL3 
register bit 7. Setting this bit enables Wide 
Ultra SCSI synchronous transfers in systems 
that have a 40MHz clock using the internal 
clock doubler. 

3. TolerANT Enable bit, STEST3 register bit 7. 
Setting this bit enables active negation. 
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Designing a Wide Ultra SCSI System 

Migrating an existing SCSI design from Fast SCSI 
to Wide Ultra SCSI requires minor software modi¬ 
fications as well as consideration for some hard¬ 
ware design guidelines. Since Wide Ultra SCSI is 
based on existing SCSI standards, it can use exist¬ 
ing software programs as long as the software is 
able to negotiate for Wide Ultra SCSI synchronous 
transfer rates. 

In the area of hardware, the primary area of con¬ 
cern in single-ended systems is to maintain signal 
integrity at high data transfer rates. To assure reli¬ 
able operation at Wide Ultra SCSI transfer speeds, 
follow the system design parameters recommended 
in the Wide Ultra SCSI Parallel Interface draft 
standard, which is available from the SCSI BBS 


referenced at the beginning of this manual. Chap¬ 
ter 6 contains Wide Ultra SCSI timing informa¬ 
tion. In addition to the guidelines in the draft 
standard, make the following software and hard¬ 
ware adjustments to accommodate Wide Ultra 
SCSI transfers: 

■ Set the Wide Ultra SCSI Enable bit to enable 
Wide Ultra SCSI transfers. 

■ Set the TolerANT Enable bit, bit 7 in the 
STEST3 register whenever the Wide Ultra 
SCSI Enable bit is set. 

■ Do not extend the SREQ/SACK filtering 
period with STEST2 bit 1. 

■ Use a 40 MHz SCSI clock with an internal 
clock doubler. 
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Interrupt Handling 

The SCRIPTS processors in the SYM53C876 
performs most functions independently of the host 
microprocessor. However, certain interrupt situa¬ 
tions must be handled by the external micropro¬ 
cessor. This section explains all aspects of 
interrupts as they apply to the SYM53C876. 

Polling and Hardware Interrupts 

The external microprocessor is informed of an 
interrupt condition by polling or hardware inter¬ 
rupts. Polling means that the microprocessor must 
continually loop and read a register until it detects 
a bit set that indicates an interrupt. This method is 
the fastest, but it wastes CPU time that could be 
used for other system tasks. The preferred method 
of detecting interrupts in most systems is hardware 
interrupts. In this case, the SYM53C876 asserts 
the Interrupt Request (INTA/ or INTB/) line that 
interrupts the microprocessor, causing the micro¬ 
processor to execute an interrupt service routine. A 
hybrid approach would use hardware interrupts for 
long waits, and use polling for short waits. 

Registers 

The registers in the SYM53C876 that are used for 
detecting or defining interrupts are the ISTAT, 
SISTO, SISTl, DSTAT, SIENO, SIENl, 

DCNTL, and DIEN. 

ISTAT 

The ISTAT is the only register that can be 
accessed as a slave during SCRIPTS operation, 
therefore it is the register that is polled when 
polled interrupts are used. It is also the first regis¬ 
ter that should be read after the INTA/ (or 
INTB/) pin is asserted in association with a hard¬ 
ware interrupt. The INTF (Interrupt on the Fly) 
bit should be the first interrupt serviced. It must 
be written to one to be cleared. This interrupt 
must be cleared before servicing any other inter¬ 
rupts. If the SIP bit in the ISTAT register is set, 
then a SCSI-type interrupt has occurred and the 
SISTO and SISTl registers should be read. If the 
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DIP bit in the ISTAT register is set, then a DMA- 
type interrupt has occurred and the DSTAT regis¬ 
ter should be read. SCSI-type and DMA-type 
interrupts may occur simultaneously, so in some 
cases both SIP and DIP may be set. 

SISTO and SISTl 

The SISTO and SISTl registers contain the SCSI- 
type interrupt bits. Reading these registers deter¬ 
mines which condition or conditions caused the 
SCSI-type interrupt, and clears that SCSI inter¬ 
rupt condition. If the SYM53C876 is receiving 
data from the SCSI bus and a fatal interrupt con¬ 
dition occurs, the chip attempts to send the con¬ 
tents of the DMA FIFO to memory before 
generating the interrupt. If the SYM53C876 is 
sending data to the SCSI bus and a fatal SCSI 
interrupt condition occurs, data could be left in 
the DMA FIFO. Because of this the DMA FIFO 
Empty (DFE) bit in DSTAT should be checked. If 
this bit is clear, set the CLF (Clear DMA FIFO) 
and CSF (Clear SCSI FIFO) bits before continu¬ 
ing. The CLF bit is bit 2 in CTEST3.The CSF bit 
is bit 1 in STEST3. 

DSTAT 

The DSTAT register contains the DMA-type 
interrupt bits. Reading this register determines 
which condition or conditions caused the DMA- 
type interrupt, and clears that DMA interrupt con¬ 
dition. Bit 7 in DSTAT, DFE, is purely a status biq 
it will not generate an interrupt under any circum¬ 
stances and will not be cleared when read. DMA 
interrupts flushes neither the DMA nor SCSI 
FIFOs before generating the interrupt, so the DFE 
bit in the DSTAT register should be checked after 
any DMA interrupt. If the DFE bit is clear, then 
the FIFOs must be cleared by setting the CLF 
(Clear DMA FIFO) and CSF (Clear SCSI FIFO) 
bits, or flushed by setting the FLF (Flush DMA 
FIFO) bit. 

SIENO and SIENl 

The SIENO and SIENl registers are the interrupt 
enable registers for the SCSI interrupts in SISTO 
and SISTl. 
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DIEN 

The DIEN register is the interrupt enable register 
for DMA interrupts in DSTAT. 

DCNTL 

When bit 1 in this register is set, the INTA/ (or 
INTB/) pin is not asserted when an interrupt con¬ 
dition occurs. The interrupt is not lost or ignored, 
but merely masked at the pin. Clearing this bit 
when an interrupt is pending immediately causes 
the INTA/ (or INTB/) pin to assert. As with any 
register other than ISTAT, this register cannot be 
accessed except by a SCRIPTS instruction during 
SCRIPTS execution. 

Fatal vs. Non-Fatal 
Interrupts 

A fatal interrupt, as the name implies, always 
causes SCRIPTS to stop running. All non-fatal 
interrupts become fatal when they are enabled by 
setting the appropriate interrupt enable bit. Inter¬ 
rupt masking is discussed later in this section. All 
DMA interrupts (indicated by the DIP bit in 
ISTAT and one or more bits in DSTAT being set) 
are fatal. 

Some SCSI interrupts (indicated by the SIP bit in 
the ISTAT and one or more bits in SISTO or 
SISTl being set) are non-fatal. When the 
SYM53C876 is operating in Initiator mode, only 
the Ftmction Complete (CMP), Selected (SEL), 
Reselected (RSL), General Purpose Timer Expired 
(GEN), and Handshake to Handshake Timer 
Expired (HTH) interrupts are non-fatal. When 
operating in Target mode CMP, SEL, RSL, Target 
mode: SATN/ active (M/A), GEN, and HTH are 
non-fatal. Refer to the description for the Disable 
Halt on a Parity Error or SATN/ active (Target 
Mode Only) (DHP) bit in the SCNTLl register to 
configure the chip’s behavior when the SATN/ 
interrupt is enabled during Target mode operation. 
The Interrupt on the Fly interrupt is also non- 
fatal, since SCRIPTS can continue when it occurs. 

The reason for non-fatal interrupts is to prevent 
SCRIPTS from stopping when an interrupt occurs 
that does not require service from the CPU. This 


prevents an interrupt when arbitration is complete 
(CMP set), when the SYM53C876 is selected or 
reselected (SEL or RSL set), when the initiator 
asserts ATN (target mode: SATN/ active), or when 
the General Purpose or Handshake to Handshake 
timers expire. These interrupts are not needed for 
events that occur during high-level SCRIPTS 
operation. 

Masking 

Masking an interrupt means disabling or ignoring 
that interrupt. Interrupts can be masked by clear¬ 
ing bits in the SIENO and SIENl (for SCSI inter¬ 
rupts) registers or DIEN (for DMA interrupts) 
register. How the chip responds to masked inter¬ 
rupts depends on: whether polling or hardware 
interrupts are being used; whether the interrupt is 
fatal or non-fatal; and whether the chip is operat¬ 
ing in Initiator or Target mode. 

If a non-fatal interrupt is masked and that condi¬ 
tion occurs, SCRIPTS do not stop, the appropri¬ 
ate bit in the SISTO or SISTl is still set, the SIP 
bit in the ISTAT is not set, and the INTA/ (or 
INTB/) pin is not asserted. See the section on non- 
fatal vs. fatal interrupts for a list of the non-fatal 
interrupts. 

If a fatal interrupt is masked and that condition 
occurs, then SCRIPTS still stop, the appropriate 
bit in the DSTAT, SISTO, or SISTl register is set, 
and the SIP or DIP bits in the ISTAT is set, but 
the INTA/ (or INTB/) pin is not asserted. 

When the chip is initialized, enable all fatal inter¬ 
rupts if you are using hardware interrupts. If a fatal 
interrupt is disabled and that interrupt condition 
occurs, SCRIPTS halts and the system never 
knows it unless it times out and checks the ISTAT 
after a certain period of inactivity. 

If you are polling the ISTAT instead of using hard¬ 
ware interrupts, then masking a fatal interrupt 
makes no difference since the SIP and DIP bits in 
the ISTAT inform the system of interrupts, not the 
INTA/ (or INTB/) pin. 
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Masking an interrupt after INTA/ (or INTB/) is 
asserted does not cause deassertion of INTA/ (or 
INTB/). 

Stacked Interrupts 

The SYM53C876 stacks interrupts if they occur 
one after the other. If the SIP or DIP bits in the 
ISTAT register are set (first level), then there is 
already at least one pending interrupt, and any 
future interrupts are stacked in extra registers 
behind the SISTO, SISTl, and DSTAT registers 
(second level). When two interrupts have occurred 
and the two levels of the stack are full, any further 
interrupts sets additional bits in the extra registers 
behind SISTO, SISTl, and DSTAT. When the first 
level of interrupts are cleared, all the interrupts 
that came in afterward moves into the SISTO, 
SISTl, and DSTAT. After the first interrupt is 
cleared by reading the appropriate register, the 
INTA/ (or INTB/) pin is deasserted for a mini¬ 
mum of three CLKs; the stacked interrupts move 
into the SISTO, SISTl, or DSTAT; and the INTA/ 
(or INTB/) pin is asserted once again. 

Since a masked non-fatal interrupt does not set the 
SIP or DIP bits, interrupt stacking does not occur. 
A masked, non-fatal interrupt still posts the inter¬ 
rupt in SISTO, but does not assert the INTA/ (or 
INTB/) pin. Since no interrupt is generated, future 
interrupts move right into the SISTO or SISTl 
instead of being stacked behind another interrupt. 
When another condition occurs that generates an 
interrupt, the bit corresponding to the earlier 
masked non-fatal interrupt is still set. 

A related situation to interrupt stacking is when 
two interrupts occur simultaneously. Since stack¬ 
ing does not occur until the SIP or DIP bits are 
set, there is a small timing window in which multi¬ 
ple interrupts can occur but are not stacked. These 
could be multiple SCSI interrupts (SIP set), multi¬ 
ple DMA interrupts (DIP set), or multiple SCSI 
and multiple DMA interrupts (both SIP and DIP 
set). 

As previously mentioned, DMA interrupts do not 
attempt to flush the FIFOs before generating the 
interrupt. It is important to set either the Clear 


DMA FIFO (CLF) and Clear SCSI FIFO (CSF) 
bits if a DMA interrupt occurs and the DMA 
FIFO Empty (DFE) bit is not set. This is because 
any future SCSI interrupts are not posted until the 
DMA FIFO is clear of data. These ‘locked out’ 
SCSI interrupts are posted as soon as the DMA 
FIFO is empty. 

Halting in an 
Orderly Fashion 

When an interrupt occurs, the SYM53C876 
attempts to halt in an orderly fashion. 

■ If the interrupt occurs in the middle of an 
instruction fetch, the fetch is completed, 
except in the case of a Bus Fault. Execution 
does not begin, but the DSP points to the next 
instruction since it is updated when the current 
instruction is fetched. 

■ If the DMA direction is a write to memory and 
a SCSI interrupt occurs, the SYM53C876 
attempts to flush the DMA FIFO to memory 
before halting. Under any other circumstances 
only the current cycle is completed before 
halting, so the DFE bit in DSTAT should be 
checked to see if any data remains in the DMA 
FIFO. 

■ SCSI SREQ/SACK handshakes that have 
begun are completed before halting. 

■ The SYM53C876 attempts to clean up any 
outstanding synchronous offset before halting. 

■ In the case of Transfer Control Instructions, 
once instruction execution begins it continues 
to completion before halting. 

■ If the instruction is a JUMP/CALL WHEN/IF 
<phase>, the DSP is updated to the transfer 
address before halting. 

■ All other instructions may halt before 
completion. 
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Sample Interrupt Service Routine 

The following is a sample of an interrupt service 
routine for the SYM53C876. It can be repeated if 
polling is used, or should be called when the 
INTA/ (or INTB/) pin is asserted if hardware 
interrupts are used. 

1. ReadlSTAT. 

2. If the INTF bit is set, it must be written to a 
one to clear this status. 

3. If only the SIP bit is set, read SISTO and 
SISTl to clear the SCSI interrupt condition 
and get the SCSI interrupt status. The bits in 
the SISTO and SISTl tell which SCSI 
interrupts occurred and determine what action 
is required to service the interrupts. 

4. If only the DIP bit is set, read the DSTAT to 
clear the interrupt condition and get the DMA 
interrupt status. The bits in the DSTAT tells 
which DMA interrupts occurred and 
determine what action is required to service 
the interrupts. 

5. If both the SIP and DIP bits are set, read 
SISTO, SISTl, and DSTAT to clear the SCSI 
and DMA interrupt condition and get the 
interrupt status. If using 8-bit reads of the 
SISTO, SISTl, and DSTAT registers to clear 
interrupts, insert a 12 CLK delay between the 
consecutive reads to ensure that the interrupts 
clear properly. Both the SCSI and DMA 
interrupt conditions should be handled before 
leaving the ISR. It is recommended that the 
DMA interrupt is serviced before the SCSI 
interrupt, because a serious DMA interrupt 
condition could influence how the SCSI 
interrupt is acted upon. 

6. When using polled interrupts, go back to step 
1 before leaving the interrupt service routine, 
in case any stacked interrupts moved in when 
the first interrupt was cleared. When using 
hardware interrupts, the INTA/ (or INTB/) pin 
is asserted again if there are any stacked 
interrupts. This should cause the system to re¬ 
enter the interrupt service routine. 


Chained Block Moves 

Since the SYM53C876 has the capability to trans¬ 
fer 16-bit wide SCSI data, a unique situation 
occurs when dealing with odd bytes. The chained 
move (CHMOV) SCRIPTS instruction along with 
the Wide SCSI Send (WSS) andWide SCSI 
Receive (WSR) bits in the SCNTL2 register are 
used to facilitate these situations. The Chained 
Block Move instruction is illustrated in Figure 2-8. 

Wide SCSI Send Bit 

The WSS bit is set whenever the SCSI controller is 
sending data (Data-Out for initiator or Data-In for 
target) and the controller detects a partial transfer 
at the end of a chained Block Move SCRIPTS 
instruction (this flag is not set if a normal Block 
Move instruction is used). Under this condition, 
the SCSI controller does not send the low-order 
byte of the last partial memory transfer across the 
SCSI bus. Instead, the low-order byte is tempo¬ 
rarily stored in the lower byte of the SODL register 
and the WSS flag is set. The hardware uses the 
WSS flag to determine what behavior must occur 
at the start of the next data send transfer. When the 
WSS flag is set at the start of the next transfer, the 
first byte (the high-order byte) of the next data 
send transfer is “married” with the stored low- 
order byte in the SODL register; and the two bytes 
are sent out across the bus, regardless of the type 
of Block Move instruction (normal or chained). 
The flag is automatically cleared when the “mar¬ 
ried” word is sent. The flag is alternately cleared 
through SCRIPTS or by the microprocessor. Also, 
the microprocessor or SCRIPTS can use this bit 
for error detection and recovery purposes. 

Wide SCSI Receive Bit 

The WSR bit is set whenever the SCSI controller is 
receiving data (Data-In for initiator or Data-Out 
for target) and the controller detects a partial 
transfer at the end of a block move or chained 
block move SCRIPTS instruction. When WSR is 
set, the high order byte of the last SCSI bus trans¬ 
fer is not transferred to memory. Instead, the byte 
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is temporarily stored in the SWIDE register. The 
hardware uses the WSR bit to determine what 
behavior must occur at the start of the next data 
receive transfer. The bit is automatically cleared at 
the start of the next data receive transfer. The bit 
can alternatively be cleared by the microprocessor 
or through SCRIPTS. Also, the microprocessor or 
SCRIPTS can use this bit for error detection and 
recovery purposes. 

SWIDE Register 

This register is used to store data for partial byte 
data transfers. For receive data, the SWIDE regis¬ 
ter holds the high-order byte of a partial SCSI 
transfer which has not yet been transferred to 
memory. This stored data may be a residue byte 
(and therefore ignored) or it may be valid data that 
is transferred to memory at the beginning of the 
next Block Move instruction. 

SODL Register 

For send data, the low-order byte of the SODL 
register holds the low-order byte of a partial mem¬ 
ory transfer which has not yet been transferred 
across the SCSI bus. This stored data is usually 
“married” with the first byte of the next data send 
transfer, and both bytes are sent across the SCSI 
bus at the start of the next data send block move 
command. 

Chained Block Move SCRIPTS 
Instruction 

A chained Block Move SCRIPTS instruction is 
primarily used to transfer consecutive data send or 
data receive blocks. Using the chained block move 
instruction facilitates partial receive transfers and 
allows correct partial send behavior without addi¬ 
tional op code overhead. Behavior of the chained 
Block Move instruction varies slightly for sending 
and receiving data. 

For receive data (Data-In for initiator or Data-Out 
for target), a chained Block Move instruction indi¬ 
cates that if a partial transfer occurred at the end of 
the instruction, the WSR flag is set.The high order 


byte of the last SCSI transfer is stored in the 
SWIDE register rather than transferred to mem¬ 
ory. The contents of the SWIDE register should be 
the first byte transferred to memory at the start of 
the chained block move data stream. Since the 
byte count always represents data transfers to/from 
memory (as opposed to the SCSI bus), the byte 
transferred out of the SWIDE register is one of the 
bytes in the bj^e count. If the WSR bit is clear 
when a receive data chained Block Move instruc¬ 
tion is executed, the data transfer occurs similar to 
that of the regular block move instruction. Whether 
the WSR bit is set or clear, when a normal block 
move instruction is executed, the contents of the 
SWIDE register is ignored and the transfer takes 
place normally. For “N” consecutive wide data 
receive Block Move instructions, the 2nd through 
the Nth Block Move instructions should be 
chained block moves. 

For send data (Data-Out for initiator or Data-In 
for target), a chained Block Move instruction indi¬ 
cates that if a partial transfer terminates the 
chained block move instruction, the last low-order 
byte (the partial memory transfer) should be 
stored in the lower byte of the SODL register and 
not sent across the SCSI bus. Without the chained 
block move instruction, the last low-order byte 
would be sent across the SCSI bus. The starting 
byte count represents data bytes transferred from 
memory but not to the SCSI bus when a partial 
transfer exists. For example, if the instruction is an 
Initiator chained Block Move Data Out of five 
bytes (and WSS is not previously set), five bytes is 
transferred out of memory to the SCSI controller, 
four bytes is transferred from the SCSI controller 
across the SCSI bus, and one byte is temporarily 
stored in the lower byte of the SODL register wait¬ 
ing to be married with the first byte of the next 
block move instruction. Regardless of whether a 
chained Block Move or normal Block Move 
instruction is used, if the WSS bit is set at the start 
of a data send command, the first b 5 ^e of the data 
send command is assumed to be the high-order 
byte and is “married” with the low-order byte 
stored in the stored in the lower b 3 ^e of the SODL 
register before the two bytes are sent across the 
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SCSI bus. For “N” consecutive wide data send 
Block Move commands, the first through the 
(Nth - 1) Block Move instructions should be 
Chained Block Moves. 


Host Memory 



00 

04 

08 

OC 

10 


SCSI Bus 


04 

03 

06 

05 

■ 

■ 



09 


OB 

OA 

OD 

OC 

■ 

■ 


[◄ 16 Bits ►] 


Notes: CHMOV 5,3 when DATAjOUT: Moves five bytes from address 03 in the host memory to the SCSI bus (bytes 03,04, 

05, and 06 are moved and byte 07 remains in the low order byte of the SCSI Output 
Data Latch register and is married with the first l^te of the foUovnng MOVE instruc¬ 
tion) 

MOVE 5,9 when DATAjOUT: Moves five bytes from address 09 in the host memory to the SCSI bus. 

Figure 2-8: Block Move and Chained Block Move Instructions 
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Parallel ROM Interface 

The SYM53C876 supports up to one megabyte of 
external memory in binary increments from 16 
KBj to allow the use of expansion ROM for add-in 
PCI cards. Both functions of the device share the 
ROM interface. This interface is designed for low- 
speed operations such as downloading instruction 
code from ROM; it is not intended for dynamic 
activities such as executing instructions. 

System requirements include the SYM53C876, 
two or three external 8-bit address holding regis¬ 
ters (HCT273 or HCT374)j and the appropriate 
memory device. The 4.7 KH pull-down resistors 
on the MAD bus require HC or HCT external 
components to be used. If in-system Flash ROM 
updates are required, a 7406 (high voltage open 
collector inverter), an MTD4P05, and several pas¬ 
sive components are also needed.The memory size 
and speed is determined by pull-down resistors on 
the 8-bit bidirectional memory bus at power-up. 
The SYM53C876 senses this bus shortly after the 
release of the Reset signal and configures the ROM 
Base Address register and the memory cycle state 
machines for the appropriate conditions. 

The external memory interface works with a vari¬ 
ety of ROM sizes and speeds. An example set of 
interface drawings is in Appendix C. 

The SYM53C876 supports a variety of sizes and 
speeds of expansion ROM, using pull-down resis¬ 
tors on the MAD(3-0) pins. The encoding of pins 
MAD (3-1) allows the user to define how much 
external memory is available to the SYM53C876. 
Table 2-5 shows the memory space associated with 
the possible values of MAD(3-l).The MAD(3-1) 
pins are fully defined in Chapter 3, ^*Signal Descrip¬ 
tions”. 


Table 2-5: 

Parallel ROM Support 

MAD(3-1) 

Available Memory Space 

000 

16 KB 

001 

32 KB 

010 

64 KB 

on 

128 KB 

100 

256 KB 

101 

512 KB 

no 

1024 KB 

111 

no external memory present 


To use one of the configurations mentioned above 
in a host adapter board design, put 4.7 KD pull¬ 
down resistors on the MAD pins corresponding to 
the available memory space. For example, to con¬ 
nect to a 32 KB external ROM, use pull-downs on 
MAD (3) and MAD (2). If the external memory 
interface is not used, then no external resistors are 
necessary since there are internal pull-ups on the 
MAD bus. The internal pull-up resistors are dis¬ 
abled when external pull-down resistors are 
detected, to reduce current drain. 

The SYM53C876 allows the system to determine 
the size of the available external memory using the 
Expansion ROM Base Address register in PCI 
configuration space. For more information on how 
this works, refer to the PCI specification or the 
Expansion ROM Base Address register description 
in Chapter 4. 

MAD(O) is the slow ROM pin. When pulled down, 
it enables two extra clock cycles of data access time 
to allow use of slower memory devices. The exter¬ 
nal memory interface also supports updates to 
flash memory. 
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Serial EEPROM Interface 

The SYM53C876 implements an interface which 
allows attachment of a serial EEPROM device to 
the GPIOO and GPIOl pins for each SCSI func¬ 
tion. There are several modes of operation. These 
relate to the serial EEPROM and the Subsystem 
ID register and Subsystem Vendor ID register for 
each SCSI function. These modes are programma¬ 
ble through the MAD6 and MAD7 pins which are 
sampled at power-up or hard reset. 


Mode A Operation 

No pulldown on MAD6, no pulldown on MAD7. 

In this mode, GPIOO is the serial data signal 
(SDA) and GPIOl is the serial clock signal (SCL). 
Certain data in the serial EEPROM is automati¬ 
cally loaded into chip registers at power-up or hard 
reset. 

The format of the serial EEPROM data is defined 
in Table 2-6. If the EEPROM is not present, or the 
checksum fails, the Subsystem ID and Subsystem 
Vendor ID registers read back all zeros. At power- 
up or hard reset, only five bytes are loaded into the 
chip from locations OOh through 04h. 

The Subsystem ID and Subsystem Vendor ID reg¬ 
isters are read only, in accordance with the PCI 
specification, with a default value of all zeros. 


Table 2-6: Mode A Serial EEPROM data format 


Byte 

Name 

Description 

OOh 

SVID(O) 

Subsystem Vendor ID, LSB. 

This byte is loaded into the 
least significant byte of the Sub¬ 
system Vendor ID register in 
the appropriate PCI configura¬ 
tion space at chip power-up or 
hard reset. 

Olh 

SVID(l) 

Subsystem Vendor ID, MSB. 

This byte is loaded into the 
most significant byte of the 
Subsystem Vendor ID register 
in the appropriate PCI configu¬ 
ration spaces at chip power-up 
or hard reset. 

02h 

SID(O) 

Subsystem ID, LSB. This byte 
is loaded into the least signifi¬ 
cant byte of the Subsystem ID 
register in the appropriate PCI 
configuration space at chip 
power-up or hard reset. 

03h 

SID(l) 

Subsystem ID, MSB. This byte 
is loaded into the most signifi¬ 
cant byte of the Subsystem ID 
register in the appropriate PCI 
configuration space at chip 
power-up or hard reset. 

04h 

CKSUM 

Checksum. This 8-bit check¬ 
sum is formed by adding, byte- 
wise, each byte contained in 
locations 00h-03h to the seed 
value 55h, and then taking the 

2’s compliment of the result. 

05h- 

FFh 

rsv 

Reserved. 

lOOh- 

EOM 

UD 

User Data. 
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Mode B Operation 

A 4.7K pulldown on MAD6j no pulldown on 
MAD7. 

In this mode, GPIOO and GPIOl are each defined 
as either the serial data signal (SDA) or the serial 
clock signal (SCL), since both pins are controlled 
through software. 

No data is automatically loaded into chip registers 
at power-up or hard reset. The Subsystem ID reg¬ 
ister and Subsystem Vendor ID register are read/ 
write, in violation of the PCI specification, with a 
default value of all zero’s. 


Mode C Operation 

A 4.7K pulldown on MAD6, and a 4.7K pulldown 
on MAD7. 

In this mode, GPIOl is the serial data signal 
(SDA) and GPIOO is the serial clock signal (SCL). 
Certain data in the serial EEPROM is automati¬ 
cally loaded into chip registers at power-up or hard 
reset. 

The format of the serial EEPROM data is defined 
in Table 2-7. If the EEPROM is not present, or the 
checksum fails, the Subsystem ID and Subsystem 
Vendor ID registers read back all zeros. At power- 
up or hard reset, only five bj^es are loaded into the 
chip from locations FBh through FFh. 

The Subsystem ID and Subsystem Vendor ID reg¬ 
isters are read only, in accordance with the PCI 
specification, with a default value of all zeros. 


Table 2-7: Mode C Serial EEPROM data format 


Byte 

Name 

Description 

OOh- 

FAh 

UDO 

User Data 

FBh 

SVID(O) 

Subsystem Vendor ID, LSB. 

This byte is loaded into the 
least significant byte of the Sub¬ 
system Vendor ID register in 
the appropriate PCI configura¬ 
tion space at chip power-up or 
hard reset. 

FCh 

SVID(l) 

Subsystem Vendor ID, MSB. 

This byte is loaded into the 
most significant byte of the 
Subsystem Vendor ID register 
in the appropriate PCI configu¬ 
ration spaces at chip power-up 
or hard reset. 

FDh 

SID(O) 

Subsystem ID, LSB. This byte 
is loaded into the least signifi¬ 
cant byte of the Subsystem ID 
register in the appropriate PCI 
configuration space at chip 
power-up or hard reset. 

FEh 

SID(l) 

Subsystem ID, MSB. This byte 
is loaded into the most signifi¬ 
cant byte of the Subsystem ID 
register in the appropriate PCI 
configuration space at chip 
power-up or hard reset. 

FFh 

CKSUM 

Checksum. This 8-bit check¬ 
sum is formed by adding, byte- 
wise, each byte contained in 
locations 00h-03h to the seed 
value 55h, and then taking the 

2’s compliment of the result. 

lOOh- 

EOM 

UD 

User Data. 
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Mode D Operation 

No pulldown on MAD6, and a 4.7K pulldown on 
MAD7. 

Note: This is a reserved mode, do not use. It may 
be redefined in future devices. 
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Signal Descriptions 


A026 

VSS 

A025 

AD24 

C_BE3/ 

VDD-IO 

IDSEL 

AD23 

VSS 

AD22 

AD21 

A020 

VDD-IO 

AD19 

VSS 

AD18 

AD17 

AD16 

VSS 

C_BE2/ 

FRAME/ 

VDD-IO 

IRDY/ 

VSS 

TROY/ 

DEVSEU 

NO_CONNECT 

STOP/ 

VSS 

PERR/ 

VDD-IO 

SERR/ 

PAR 

C_BE1/ 

VSS 

AD1S 

AD14 

A013 

VDO-IO 

AD12 

VSS 

AD11 

A010 

AD9 

VSS 

A08 

VDO-IO 

C_BE0/ 

AD7 

A06 

VSS 

ADS 



A_SD7/ 

A_SDPO/ 

A_SATN/ 

VSS-S 

A_SBSY/ 

A_SACK/ 

A.SRST/ 

A_SMSG/ 

A_SSEL/ 

VSS-S 

A_SC_D/ 

A_SREQ/ 

A_SLO/ 

A_SD8/ 

VSS-S 

A. SD9/ 
A_SD10/ 
A_SD11/ 
VOD 

A_SDIR8 

A_SDIR9 

A_SDIR10 

/LSDIR11 

VSS 

A_BSYDIR 

VDD-C 

A_RSTDIR 

VSS-C 

A_SELDIR 

A_IGS 

A_TGS 

A_DIFFSENS 

VDD 

B_SD12/ 

B_SD13/ 

B_SD14/ 

VSS-S 

B_SD15/ 

B_SDP1/ 

B_SDO/ 

B_S01/ 

VSS-S 

B_SD2/ 

B_SD3/ 

B_SD4/ 

B_SD5/ 

VSS-S 

B_SD6/ 

B_SD7/ 

B. SDPO/ 
B_SATN/ 
VSS-S 


Figure 3-1: SYM53C876 208-Pm PQFP Diagram 
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1 

2 

3 

4 

5 

6 

7 

8 

9 

10 

11 

12 

13 

14 

15 

16 

17 

18 

19 

20 

A 

vss 

AD27 

AD30 

REQ/ 

RST/ 

MCE/ 

MWE/ 

BJGS 

B_S0IR13 

VDD 

A_SOIR13 

A_SDIR0 

A_SDIR4 

A_SDIR7 

A_SD12/ 

A_SDP1/ 

A_SD2/ 

A_SD3/ 

A_SD6/ 

A_SD7/ 

B 

A026 

AD26 

VOO-IO 

AD31 

GNT/ 

INTA/ 

MOE/_TO 

MAS1/ 

VDD 

A_SOIR12 

A_SOIR15 

A.SDIR1 

A.SDIR5 

A_DIRPQ/1 

A_SD13/ 

A_SD0/ 

A_SD4/ 

A_SD5/ 

/LSDPQ/ 

A_SATN/ 

C 

A024 

VSS 

NC 

A029 

VOO-C 

VSS-C 

INTB/ 

MASIV 

B_SDIR12 

B.SDIRIS 

A.S0IR14 

A.SDIR2 

A.SDIR6 

VDD 

A_SD15/ 

A.SD1/ 

NC 

NC 

A_SBSy/ 

A_SRST/ 

D 

C_BE3/ 

A02S 

NC 

VSS 

VSS 

NC 

CLK 

VSS 

B.TGS 

B.SDIR14 

NC 

A_SDIR3 

VSS 

A_SD14/ 

NC 

NC 

VSS 

NC 

A_SMSG/ 

A_SC_D/ 

E 

AD23 

lOSEl 

VDO-IO 

NC 

SYIVI53C876 

256-Bump 

Ball Grid Array 

A_SACK/ 

A.SSEL/ 

/LSREQ/ 

A.SD9/ 

F 

A021 

AD22 

VSS 

NC 

NC 

A.SLO/ 

A_SD10/ 

VDD 

G 

A019 

VDD-IO 

A020 

NC 

A_SD8/ 

A.S011/ 

A_SOIR8 

A_SDIR9 

H 

ADI 7 

A01B 

VSS 

VSS 

VSS 

A_SDIR10 

A_SOIR11 

A.BSYDIR 

J 

FRAME/ 

C_B£2/ 

VSS 

AD16 

VDD-C 

A_RST0IR 

VSS-C 

A_SELDIR 

K 

VSS 

VD040 

IRDY/ 

NC 

A-IGS 

A,TGS 

A_DIFSEN 

VDO 

L 

TRDY/ 

OEVSEL/ 

NC 

STOP/ 

NC 

B.SDIRI 

B_SDIR2 

B_SDIR0 

M 

VSS 

PERR/ 

VDD-IO 

SERR/ 

B_SDIR6 

B.SDIRS 

B_SDIR4 

B_SDIR3 

N 

PAR 

C.BEV 

VSS 

VSS 

VSS 

VDD 

B_DIRP0/1 

B_SOIR7 

P 

ADIS 

A014 

VDD-IO 

A011 

BJOO/ 

B_SD14/ 

B_SD13/ 

B_SD12/ 

R 

A013 

A012 

A010 

NC 

NC 

B_SD1/ 

B_SDP1/ 

B_SD15/ 

T 

VSS 

AD9 

A08 

NC 

NC 

B_SD4/ 

B_S03/ 

B_SD2/ 

U 

VSS 

VOO-IO 

NC 

VSS 

vss 

NC 

VOO-C 

VSS 

MA07 

NC 

B.GPlOO 

B_GPI04 

VSS 

VDD 

NC 

B.SC.D/ 

VSS 

NC 

B_S07/ 

B.SDS 

V 

C_BE0/ 

A07 


AD2 

TCK 

TOO 

VSS-C 

A_GPI02 

VDD 

MAD4 

MADO 

B_GPI03 

B.RSTDIR 

B_SDIR9 

B_SD11/ 

B_SD8/ 

B_SSEU 

NC 

B_SDPO/ 

B_SD6/ 

W 

AD6 

VSS 

A04 

VDO-IO 

TDI 

SCLK 

A.6PI00 

A.GPI03 

MA06 

NC 

MA01 

B_GPI02 

blseldir 

B_SDIR11 

B.SOIRB 

B.SDIO/ 

B.SLO/ 

B_SMSG/ 

B.SACK/ 

B.SATN/ 

Y 

AOS 

A03 

ADI 

ADO 

TMS 

TESTIN/ 

A.GPI01 

A.GPI04 

MAOS 

MA03 

MAD2 

B.GPIOI 

VDD 

B.BSYDIR 

B.SDIRIO 

B.DIFSEN 

B_SD9/ 

B.SREQ/ 

B.SRST/ 

B.SBSY/ 


Figure 3-2: SYM53C876 256-Bump BGA Diagram (top view) 
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PREUMINARY 


Signal Descriptions 


SYM53C876 


Address and Data 


Interface 


Interface Control 


Arbitration | 


Error Reporting 


Interrupt 


SCSI 

Function A 
GRID 


SCSI 

Function B 
GRID 


ROM/Flash 

Memory 

Interface 


AD(3^0) 

C_BE(3-0) 


FRAME/ 

TRDY/ 


DEVSEL/ 

IDSEL 


A.SCTRiy 


SCTRL/ 


A_GRIOO_FETCH/ 

A_GRI01_MASTER/ 

A_GRI02 

A_GRI03 

A_GRI04 

B_GRIOO_FETCH/ 

B_GRI01_MASTER/ 

B_GRI02 

B_GRI03 

B_GRI04 

MWE/ 

MCE/ 

M0E_TEST0UT 

MASO/ 

MAS1/ 

MAD7-0 


SCLK 
A_SD15-0/ 
A_SDR1-0/ 
r- A_SC_D/ 
A_SLO/ 
A_SMSG/ 
A_SREQ/ 
A_SACK/ 
A_SBSY/ 
A_SATN/ 
A_SRST/ 
•— A_SSEL/ 
A_SDIR15-0/ 
A_SDIRR0/1 
A_BSYDIR 
A_SELDIR 
A_RSTDIR 
A_DIFFSENS 
AJGS 
A_TGS 

B_SD15-0/ 
B_SDR1-0/ 
I- B_SC_D/ 
B_SL0/ 
B_SMSG/ 
B_SREQ/ 
B_SACK/ 
B_SBSY/ 
B_SATN/ 
B_SRST/ 
L- B_SSEL/ 
B_SDIR15-0/ 
B_SDIRR0/1 
B_BSYDIR 
B.SELDIR 
B.RSTDIR 
B_DIFFSENS 
B_IGS 
B_TGS 

TESTIN/ 

TCK 

IMS 

TDI 

TDD 


SCSI Function A 
SCSI Bus 
Interface 


SCSI Function A 
Differential 
Control 


SCSI Function B 
SCSI Bus 
Interface 


SCSI Function B 
Differential 
Control 

(256 BGA only) 


Test 

Interface 
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Signal Descriptions 


PREUMINARY 


The SYM53C876 signals are divided into three primary interfaces: 

■ PCI Interface 

■ SCSI Interface 

■ ROM/Flash Memory Interface 

The PCI interface signals are organized into the following functional groups: System, Address and Data, 
Interface Control, Arbitration, Error Reporting, Interrupt, and GPIO.The SCSI interface signals are 
organized into the following functional groups: data and parity group and SCSI control group. 

A slash (/) at the end of the signal name indicates that the active state occurs when the signal is at a low 
voltage. When the slash is absent, the signal is active at a high voltage. 

There are four signal type definitions: 

I Input, a standard input-only signal 

O Totem Pole Output, a standard output driver 

I/O Input and output (bi-directional) 

T/S Tri-State, a bi-directional, tri-state input/output signal 

S/T/S Sustained Tri-state, an active low tri-state signal owned and driven by one and only one agent at 

a time 
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Signal Descriptions 

PCI Interface Pins 


PCI Interface Pins 


System Pins 


Table 3-1: PCI Interface Pins 


Pin Name 

Pin/Bump Number 

Type 

Strength 

Description 

CLK 

197, D7 

I 

N/A 

Clock provides timing for all transactions on the PCI bus 
and is an input to every PCI device. All other PCI signals 
are sampled on the rising edge of CLK, and other timing 
parameters are defined with respect to this edge. Clock 
can optionally serve as the SCSI core clock, but this may 
effect Fast SCSI transfer rates. 

RST/ 

196,A5 

I 

N/A 

Reset forces the PCI sequencer of each device to a known 
state. All t/s and s/t/s signals are forced to a high imped¬ 
ance state, and all internal logic is reset. The RST/ input is 
synchronized internally to the rising edge of CLK. The 

CLK input must be active while RST/ is active to properly 
reset the device. 
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Signal Descriptions 

PCI Interface Pins 


PRELIMINARY 


Address/Data Pins 

Table 3-2: PCI Interface Pins 

Pin Name Pin/Bump Number Type Strength Description 

AD(31-0) 202,203,205, T/S 16 mA PCI Physical longword address and data are multiplexed on 

207, 208, 1,3,4, the same PCI pins. During the first clock of a transac- 

8,10,11,12,14, tion, AD(31-0) contain a physical byte address. During 

16,17,18, 36, subsequent clocks, AD(31-0) contain data. A bus trans- 

37, 38,40,42, action consists of an address phase followed by one or 

43, 44,46, 49, more data phases. PCI supports both read and write 

50, 52, 53, 54, bursts. AD(7-0) define the least significant byte, and 

56, 58, 59 AD(31-24) define the most significant byte. 

B4,A3, C4, B2, 

A2,B1,D2,C1, 

E1,F2,F1,G3, 

G1,H2,H1,J4, 

P1,P2, R1,R2, 

P4, R3,T2,T3, 

V2,W1,Y1,W3, 

Y2,V4,Y3,Y4 

5,20,34,48 T/S 16 mA PCI Bus command and byte enables are multiplexed on 
Dl, J2, N2, VI the same PCI pins. During the address phase of a trans¬ 

action, C_BE/(3-0) define the bus command. During 
the data phase, C_BE/(3-0) are used as byte enables. 
The byte enables determine which byte lanes carry 
meaningful data. C_BE/(0) applies to byte 0, and C_BE/ 
(3) to byte 3. 

PAR 33, N1 T/S 16 mA PCI Parity is the even parity bit that protects the AD(31-0) 

and C_BE/(3-0) lines. During address phase, both the 
address and command bits are covered. During data 
phase, both data and byte enables are covered. 


C_BE/ 

(3-0) 
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Signal Descriptions 

PCI Interface Pins 


Interface Control Pins 


Table 3-3: PCI Interface Pins 


Pin Name 

Pin/Bump 

Number 

Type 

strength 

Description 

FRAME/ 

21J1 

sms 

16 mA PCI 

Cycle Frame is driven by the current master to indicate 
the beginning and duration of an access. FRAME/ is 
asserted to indicate that a bus transaction is beginning. 
While FRAME/ is deasserted, either the transaction is in 
the final data phase or the bus is idle. 

TRDY/ 

25, LI 

sms 

16 mA PCI 

Target Ready indicates the target agent’s (selected 
device’s) ability to complete the current data phase of the 
transaction. TRDY/ is used with IRDY/. A data phase is 
completed on any clock when used with IRDY/. A data 
phase is completed on any clock when both TRDY/ and 
IRDY/ are sampled asserted. During a read, TRDY/ indi¬ 
cates that valid data is present on AD (31-0). During a 
write, it indicates that the target is prepared to accept data. 
Wait cycles are inserted until both IRDY/ and TRDY/ are 
asserted together. 

IRDY/ 

23, K3 

sms 

16 mA PCI 

Initiator Ready indicates the initiating agent’s (bus mas¬ 
ter’s) ability to complete the current data phase of the 
transaction. IRDY/ is used with TRDY/. A data phase is 
completed on any clock when both IRDY/ and TRDY/ are 
sampled asserted. During a write, IRDY/ indicates that 
valid data is present on AD (31-0). During a read, it indi¬ 
cates that the master is prepared to accept data. Wait cycles 
are inserted until both IRDY/ and TRDY/ are asserted 
together. 

STOP/ 

28, L4 

sms 

16 mA PCI 

Stop indicates that the selected target is requesting the 
master to stop the current transaction. 

DEVSEI7 

26, L2 

sms 

16 mA PCI 

Device Select indicates that the driving device has 
decoded its address as the target of the current access. As 
an input, it indicates to a master whether any device on the 
bus has been selected. 

IDSEL 

7, E2 

I 

N/A 

Initialization Device Select is used as a chip select in 
place of the upper 24 address lines during configuration 
read and write transactions. 
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Signal Descriptions 

PCI Interface Pins 


PRELIMINARY 


Arbitration Pins 


Table 3-4; PCI Interface Pins 


Pin Name 

Pin/Bump Number 

Type 

Strength 

Description 

REQ/ 

200, A4 

O 

16 mA PCI 

Request indicates to the system arbiter that this agent 
desires use of the PCI bus. Both SCSI functions share the 
GNT/ signal. 

GNT/ 

199, B5 

I 

N/A 

Grant indicates to the agent that access to the PCI bus 
has been granted. Both SCSI functions share the GNT/ 
signal. 






Error Recording Pins 







Table 3-5: PCI Interface Pins 

Pin Name 

Pin/Bump 

Number 

Type 

Strength 

Description 

PERR/ 

30, M2 

S/T/S 

16 mA PCI 

Parity Error may be pulsed active by an agent that 
detects a data parity error. PERR/ can be used by any 
agent to signal data corruption. However, on detection of 
a PERR/ pulse, the central resource may generate a non¬ 
maskable interrupt to the host CPU, which often implies 
the system is unable to continue operation once error pro¬ 
cessing is complete. 

SERR/ 

32, M4 

O 

16 mA PCI 

This open drain output is used to report address parity 
errors. 
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Signal Descriptions 

PCI Interface Pins 


PCI Interrupt Pins 


Table 3-6: PCI Interrupt Pins 


Pin Name 

Pin/Bump Number 

Type 

Strength 

Description 

INTA/ 

195, B6 

O 

16 mA PCI 

Interrupt Function A. This signal, when asserted low, 
indicates that an interrupting condition in SCSI Fimction 

A and that service is required from the host CPU. The out¬ 
put drive of this pin is open drain with an internal weak 
pull-up. If the SCSI Function B interrupt is rerouted at 
power up via the INTA/ enable sense resistor (pulldown 
on MAD4), then this signal indicates an interrupt in either 
SCSI Function A or SCSI Function B. 

INTB/ 

194, C7 

O 

16 mA PCI 

Interrupt Function B. This signal, when asserted low, 
indicates an interrupting condition in SCSI Function B 
and that service is required from the host CPU. The out¬ 
put drive of this pin is open drain with an internal weak 
pull-up. This interrupt can be rerouted at powerup via the 
INTA/ enable sense resistor (pull-down on MAD4).This 
causes the SYM53C876 to program the SCSI Function B 
PCI register Interrupt Pin (3D) to Olh. 
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Signal Descriptions 

PCI Interface Pins 


PREUMINARY 


GPIO Interface Pins 


Table 3-7: GPIO Interface Pins 


Pin Name 

Pin/Bump 

Number 

Type 

Strength 

Description 

A_GPIOO_ 

FETCH/ 

68, W7 

I/O 

16 mA 

SCSI Function A General Purpose I/O pin 0. Option¬ 
ally, when driven low, indicates that the next bus request 
is for an op code fetch. This pin is programmable at pow- 
erup through the MAD(7:6) pins to serve as either the 
data or clock signal for the serial EEPROM interface. 

B_GPIOO_ 

FETCH/ 

84, U11 

I/O 

16 mA 

SCSI Function B General Purpose I/O pin 0. Option¬ 
ally, when driven low, indicates that the next bus request 
is for an op code fetch. This pin is programmable at pow- 
erup through the MAD(7:6) pins to serve as either the 
data or clock signal for the serial EEPROM interface. 

A_GPI01_ 

MASTER/ 

69,Y7 

I/O 

16 mA 

SCSI Function A General purpose I/O pin 1. Option¬ 
ally, when driven low, indicates that the SYM53C876 is 
bus master. This pin is programmable at powerup through 
the MAD(7:6) pins to serve as either the data or clock sig¬ 
nal for the serial EEPROM interface. 

B_GPI01_ 

MASTER/ 

86,Y12 

I/O 

16 mA 

SCSI Function B General purpose I/O pin 1. Option¬ 
ally, when driven low, indicates that the SYM53C876 is 
bus master. This pin is programmable at powerup through 
the MAD(7:6) pins to serve as either the data or clock sig¬ 
nal for the serial EEPROM interface. 

A_GPI02 

70,V8 

I/O 

16 mA 

SCSI Function A General Purpose I/O pin 2. Option¬ 
ally, this pin is used as Memory Address Strobe 2 if an 
external memory with more than 16 bits of addressing is 
specified by the pulldown resistors at power up and bit 0 
in the expansion ROM Base Address register is set. This 
pin powers up as an input. 

B_GPI02 

87,W12 

I/O 

16 mA 

SCSI Function B General purpose I/O pin 2. 
B_GPI02 powers up as an input. 

A_GPI03 

71,W8 

I/O 

16 mA 

SCSI Function A General purpose I/O pin 3. 
A_GPI03 powers up as an input. 

B_GPI03 

88,V12 

I/O 

16 mA 

SCSI Function B General purpose I/O pin 3. 
B_GPI03 powers up as an input. 

A_GPI04 

73,Y8 

I/O 

16 mA 

SCSI Function A General purpose I/O pin 4. 
A_GPI04 powers up as an output. It can be used as the 
enable line forVPP, the 12 Volt power supply to the exter¬ 
nal flash memory interface. 

B_GPI04 

89,U12 

I/O 

16 mA 

SCSI Function B General purpose I/O pin 4. 


B_GPI04 powers up as an output. It can be used as the 
enable line forVPP, the 12 Volt power supply to the exter¬ 
nal flash memory interface. 
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Signal Descriptions 

SCSI Interface Pins 


SCSI Interface Pins 


Table 3-8: SCSI Interface Pins 


Pin Name 

Pin/Bump Number 

Type 

Strength 

Description 

SCLK 

65, W6 

I 

N/A 

SCSI Clock is used to derive all SCSI-related tim¬ 
ings. The speed of this clock is determined by the 
applications requirements. In some applications, 

SCLK id sourced internally from the PCI bus clock 
(CLK). If SCLK is internally sourced, tie the SCLK 
pin low. For Ultra SCSI operations, the clock sup¬ 
plied to SCLK must be at 40 MHz. This frequency is 
doubled to create the 80 MHz clock required by both 
SCSI functions. 

A_SD/(15-0), 

A_SDP/(l-0) 

167, 169, 170, 
171, 139, 140, 
141, 143,156, 
157, 159, 160, 
161, 162,164, 
165, 166, 155, 
C15,D14,B15, 
A15, G18,F19, 
E20,G17,A20, 
A19,B18,B17, 
A18,A17,C16, 
B16,A16,B19 

I/O 

48 mA 
SCSI 

SCSI Function A Data includes the following data 
lines and parity signals: A_SD/(15-0) (16-bit SCSI 
data bus), and A_SDP/(l-0) (SCSI data parity bits). 

B_SD/(15-0), 

B_SDP/(l-0) 

119,121,122, 
123,91,92, 93, 
95,108, 109, 
111, 112,113, 
114, 116,117, 
118,107, 
R20,P18,P19, 
P20,V15,W16, 
Y17,V16,U19, 
V20,U20,T18, 
T19,T20, R18, 
P17, R19,V19 

I/O 

48 mA 
SCSI 

SCSI Function B Data includes the following data 
lines and parity signals: B_SD/(15-0) (16-bit SCSI 
data bus), and B_SDP/(l-0) (SCSI data parity bits). 
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Signal Descriptions 

SCSI Interface Pins 


PREUMINARY 


Table 3-8: SCSI Interface Pins 


A.SCTRIV 

146,144,149, I/O 

48 mA 

SCSI Function A Control includes the following 


145, 151, 152, 

SCSI 

signals: 


154, 150, 148, 


A_SC_D/ - SCSI phase line, command/data 


D20,F18,D19, 


A_SI_0/ - SCSI phase line, input/output 


E19,E17,C19, 


A_SMSG/ - SCSI phase line, message 


B20, C20,E18 


A_SREQ/ •• Data handshake line from target device 
A_SACK/ - Data handshake signal from initiator 
device 

A_SBSY/ - SCSI bus arbitration signal, busy 
A_SATN/ - SCSI Attention, the initiator is request¬ 
ing a message out phase 




A_SRST/ - SCSI bus reset 

A_SSEL/ - SCSI bus arbitration signal, select device 

B_SCTRI7 

98,96, 101,97, I/O 

48 mA 

SCSI Function B Control includes the following 


103,104,106, 

SCSI 

signals: 


102, 100, 


B_SC_D/ - SCSI phase line, command/data 


U16,W17,W18, 


B_SI_0/ - SCSI phase line, input/output 


Y18,W19,Y20, 


B_SMSG/ - SCSI phase line, message 


W20,Y19,V17 


B_SREQ/ - Data handshake line from target device 
B_SACK/ - Data handshake signal from initiator 
device 




B_SBSY/ - SCSI bus arbitration signal, busy 
B_SATN/ - SCSI Attention, the initiator is request¬ 
ing a message out phase 




B_SRST/ - SCSI bus reset 

B_SSEL/ - SCSI bus arbitration signal, select device 
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Signal Descriptions 

SCSI Interface Pins 


Differential Control Pins 


Table 3-9: Differential Control Pins 


Pin Name 

Pin/Bump Number 

Type 

Strength 

Description 

A_SDIR(15-0) 

183, 184, 185, 
187, 134, 135, 
136,137,174, 
175, 176, 177, 
179, 180, 181, 
182, 

O 

4 mA 

Driver direction control for SCSI Function A data 
lines. 


B11,C11,A11, 

B10,H19,H18, 

G20,G19,A14, 

C13,B13,A13, 

D12,C12,B12, 

A12 




A_SDIRP0/1 

173, B14 

O 

4mA 

Driver direction control for SCSI Function A par¬ 
ity line. 

A_BSYDIR 

132, H20 

O 

4 mA 

Driver enable control for SCSI Function A SBSY/ 
signal. 

A.SELDIR 

128,J20 

O 

4 mA 

Driver enable control for SCSI Function A SSEL/ 
signal. 

A_RSTDIR 

130,J18 

O 

4 mA 

Driver enable control for SCSI Function A SRST/ 
signal. 

A.DIFFSENS 

125, K19 

I 

N/A 

SCSI Function A Differential Sense. This pin 
detects the presence of a single-ended device on a 
differential system. When external differential 
transceivers are used, and a zero is detected on this 
pin, all SCSI Function A chip outputs are tri- 
stated to avoid damage to the transceivers. Tie this 
pin high during single-ended operation. The nor¬ 
mal value of this pin is one. 

A_TGS 

126, K18 

O 

4 mA 

SCSI Function A direction control for target driver 
group. 

A_IGS 

127, K17 

O 

4 mA 

SCSI Function A direction control for initiator 
driver group. 

B_SDIR(15-0) 

CIO, DIO, A9, 
C9,W14,Y15, 

O 

4 mA 

Driver direction control for SCSI Function B data 
lines. 


V14,W15, N20, 
Ml 7, Ml 8, 
M19,M20, LI 9, 
L18,L20 
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Signal Descriptions 

SCSI Interface Pins 


PRELIMINARY 


Table 3-9: DifTerendal Control Pins 


B_SDIRP0/1 

N19 

O 

4 mA 

Driver direction control for SCSI Function B par¬ 
ity line. 

B_BSYDIR 

Y14 

O 

4 mA 

Driver enable control for SCSI Function B SBSY/ 
signal. 

B_SELDIR 

W13 

o 

4 mA 

Driver enable control for SCSI Function B SSEL/ 
signal. 

B_RSTDIR 

V13 

o 

4 mA 

Driver enable control for SCSI Function B SRST/ 
signal. 

B_DIFFSENS 

Y16 

I 

N/A 

SCSI Function B DifTerendal Sense. This pin 
detects the presence of a single-ended device on a 
differential system. When external differential 
transceivers are used, and a zero is detected on this 
pin, all SCSI Function B chip outputs are tri- 
stated to avoid damage to the transceivers. Tie this 
pin high during single-ended operation. The nor¬ 
mal value of this pin is one. 

B_TGS 

D9 

o 

4 mA 

SCSI Function B direction control for target driver 
group. 

B_IGS 

A8 

o 

4 mA 

SCSI Function B direction control for initiator 
driver group. 
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Signal Descriptions 

ROM/Flash Interface Pins 


ROM/Flash Interface Pins 


Table 3-10: ROM/Flash Interface Pins 


Pin Name 

Pin/Bump 

Number 

Type 

Strength 

Description 

MASO/ 

190, C8 

O 

4 mA 

Memory Address Strobe O.This pin is used to latch in 
the least significant address byte of an external EPROM 
or flash memory. Since the SYM53C876 moves 
addresses eight bits at a time, this pin connects to the 
clock of an external bank of flip-flops which are used to 
assemble up to a 20-bit address for the external memory. 

MASl/ 

189, B8 

O 

4 mA 

Memory Address Strobe l.This pin is used to latch in 
the address byte corresponding to address bits 15-8 of an 
external EPROM or flash memory. Since the 

SYM53C876 moves addresses eight bits at a time, this 
pin connects to the clock of an external bank of flip-flops 
which assemble up to a 20-bit address for the external 





memory. 

MAD7-0 

74, 76, 

I/O 

4 mA 

Memory Address/Data Bus. This bus is used in con- 


77, 79, 



junction with the memory address strobe pins and exter- 


80,81, 



nal address latches to assemble up to a 20-bit address for 


82, 83, 



an external EPROM or flash memory. This bus puts out 


U9,W9, 



the least significant byte first and finishes with the most 


Y9,V10, 



significant bits. It is also used to write data to a flash 


Y10,Y11, 



memory or read data into the chip firom external 


W11,V11 



EPROM/flash memory. All MAD pins have internal 
pull-up resistors. 

MWE/ 

191,A7 

O 

4 mA 

Memory Write Enable. This pin is used as a write 
enable signal to an external flash memory. 

MOE/_TESTOUT 

192, B7 

O 

4 mA 

Memory Output Enable.This pin is used as an output 
enable signal to an external EPROM or flash memory 
during read operations. It is also used to test the connec¬ 
tivity of the SYM53C876 signals in the “AND-tree” test 
mode. This pin is only driven as the Test Out function 
when theTESTIN/ pin is driven low. 

MCE/ 

193,A6 

O 

4 mA 

Memory Chip Enable. This pin is used as a chip 
enable signal to an external EPROM or flash memory 
device. 
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Test Pins 


PRELIMINARY 


Test Pins 


Table 3-11: Test Pins 


Pin Name ^Numbier* Strength Description 

MOE/_TESTOUT 192, B7 O 4 mA Test Out. This pin is used to test the connectivity of 

the SYM53C876 signals in the “AND-tree” test 
mode. It is also used as an output enable signal to an 
external EPROM or flash memory during read oper¬ 
ations. This pin is only driven as the Test Out func¬ 
tion when theTESTIN/ pin is driven low. 


TESTIN/ 

66,Y6 

I 

N/A 

Test In, When this pin is driven low, the 

SYM53C876 connects all inputs and outputs to an 
“AND tree”. The SCSI control signals and data 
lines are not connected to the tree. The output of the 
“AND tree” is connected to the Test Out pin (MOE/ 
_TESTOUT). When theTESTIN/ pin is driven low 
internal pull-ups are enabled on all input, output, 
and bidirectional pins; all output and bidirectional 
pins signals are tri-stated; and the MOE/ 

_TESTOUT pin is enabled. Connectivity is tested 
by driving one of the SYM53C876 pins low. The 
MOE/_TESTOUT should respond by also driving 
low. 

TCK 

60, V5 

I 

N/A 

Test Clock. This pin provides the clock for the 

JTAG test logic. It has a static pull-up. 

TMS 

62,Y5 

I 

N/A 

The signal received at TMS is decoded by the TAP 
controller to control JTAG test operations. It has a 
static pull-up. 

TDI 

61,W5 

I 

N/A 

Test Data In.Serial test instructions are received by 
the JTAG test logic at this pin. It has a static pull-up. 

TDO 

63, V6 

O 

N/A 

Test Data Out. This pin is the serial output for test 
instructions and data from the JTAG test logic. 
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Power and Ground Pins 

Table 3-12: Power and Ground Pins 


Pin Name 

Pin/Bump Number 

Type 

Strength 

Description 

Vdd-IO 

6, 13, 22,31,39, 
47, 55,206, 

B3, E3, G2, K2, 
M3, P3, U2,W4 

P 

N/A 

Power for PCI bus drivers/receivers. 

Vss 

2, 9,15,19, 24, 
29,35,41,45, 
51,57, 204, 
A1,C2, D4,D5, 
D8,D13,D17, 
F3, H3, H4, 
H17,J3,K1,M1, 
N3,N4,N17, 
T1,U1,U4, U5, 
U8,U13,U17, 
W2 

G 

N/A 

Ground for PCI bus drivers/receivers. 

Vdd 

90,124, 138, 
172, 

A10,C14,F20, 

K20,N18,U14, 

V9,Y13 

P 

N/A 

Power for SCSI bus drivers/receivers. 

Vss-S 

94,99, 105,110, 
115, 120, 142, 
147, 153, 158, 
163,168 

G 

N/A 

Ground for SCSI bus drivers/receivers. 

Vdd~C 

64, 131,201, 
C5,J17, U7 

P 

N/A 

Power for core logic. 

Vss-C 

67, 129, 198, 
C6,J19,V7 

G 

N/A 

Ground for core logic. 

VdD 

75,186 

P 

N/A 

Power for other I/O. 

Vss 

72,85, 133,178, 
188 

G 

N/A 

Ground for other I/O. 
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MAD Bus Programming 

The MAD (7-0) pins, in addition to serving as the address/data bus for the local memory interface, also 

are used to program power-up options for the chip. A particular option is programmed by connecting a 

4.7 KD resistor between the appropriate MAD(x) pin andVgs.The pull-down resistors require that HC 

or HCT external components are used for the memory interface. 

■ MAD(7) Serial EEPROM programmable option. Please refer to the Serial EEPROM Interface and 
Subsystem ID / Subsystem Vendor ID Operating Modes section in Chapter 2 for details. 

■ MAD(6) Serial EEPROM programmable option. Please refer to the Serial EEPROM Interface and 
Subsystem ID / Subsystem Vendor ID Operating Modes section in Chapter 2 for details. 

■ MAD (5) Scripts RAM disable. 

■ MAD(4) E>rrA/ routing enable. Placing a pull-down resistor on this pin causes SCSI Function B 
interrupt requests to appear on the INTA/ pin, along with SCSI Function A interrupt requests, 
instead of on INTB/. Placing a pull-down resistor on this pin also causes the SCSI Function B 
interrupt pin register (3Dh) in PCI configuration space to be programmed to Olh instead of 02h. 

■ The MAD(3-1) pins are used to set the size of the external expansion ROM device attached. 
Encoding for these pins are listed in the following table (“0” indicates a pull-down resistor is attached, 
“1” indicates no pull-down resistor attached). 


Table 3-13: 

Decode of IViAD pins 

MAD(3-1) 

Available Memory Space 

000 

16 KB 

001 

32 KB 

010 

64 KB 

on 

128 KB 

100 

256 KB 

101 

512 KB 

no 

1024 KB 

111 

no external memory present 


■ The MAD(O) pin is the slow ROM pin. When pulled down, it enables two extra cycles of data access 
time to allow use of slower memory devices. 

■ All MAD pins have internal pull-up resistors. 
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Configuration Registers 

The Configuration registers are accessed by per¬ 
forming a configuration read/write to the device 
with its IDSEL pin asserted and the appropriate 
value in AD(10:8) during the address phase of the 
transaction. SCSI Function A is identified by a 
binary value of 000b, and SCSI Function B by a 
value of 001b. Each SCSI function contains the 
same register set with identical default values, 
except the Interrupt Pin register. 


Table 4-1 shows the PCI configuration registers 
implemented by the SYM53C876. 

All PCI-compliant devices, such as the 
SYM53C876, must support the Vendor ID, Device 
ID, Command, and Status Registers. Support of 
other PCI-compliant registers is optional. In the 
SYM53C876, registers that are not supported are 
not writable and return all zeroes when read. Only 
those registers and bits that are currently sup¬ 
ported by the SYM53C876 are described in this 
chapter. 


SCSI Function A, AD(10-8) = 000 binary 
SCSI Function B, AD(10-8) = 001 binary 


Table 4-1: PCI-to-SCSI Configuration Register Map 


31 

16 

15 

0 

Device ID 

Vendor ID = lOOOh 

Status 

Command 

Class Code 

Rev ID 

BIST 

Header Type 

Latency Timer 

Cache Line Size 

Base Address Zero (FO), SCSI Operating Registers 

Base Address One (Memory), SCSI Operating Registers 

Base Address Two (Memory) SCRIPTS RAM 

Not Supported 

Not Supported 

Not Supported 




Subsystem ID 

Subsystem Vendor ID 

Expansion ROM Base Address 



ITVCci 






Max_Lat 

Min_Gnt 

Interrupt Pin 

Interrupt Line 


OOh 

04h 

08h 

OCh 

lOh 

14h 

18h 

ICh 

20h 

24h 

28h 

2Ch 

30h 

34h 

38h 

3Ch 
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Register OOh 

Register 02h 

Vendor ID 

Device ID 

Read Only 

Read Only 



This field identifies the manufacturer of the device. This field identifies the particular device. The 

The Symbios Logic Vendor ID is lOOOh. SYM53C876 Device ID is OOOFh. 
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Register 04h 

Command 

ReadlWrite 


-m' 

SE 


EPER 


WIE 

RES 

EBM 

EMS 

EIS 

15-9 

8 

1 

6 

s 

4 

3 

2 

1 

0 

Default »> 

0 0 

0 

0 

0 

0 

0 

0 

0 

0 


The SCSI Command Register provides coarse 
control over a device’s ability to generate and 
respond to PCI cycles. When a zero is written to 
this register, the SYM53C876 is logically discon¬ 
nected from the PCI bus for all accesses except 
configuration accesses. 

Bits 15-9 Reserved 

Bit 8 SERRI Enable(SE) 

This bit enables the SERR/ driver. SERR/ is 
disabled when this bit is clear. The default 
value of this bit is zero. Set this bit and bit 6 to 
report address parity errors. 

Bit 7 Reserved 

Bit 6 Enable Parity Error Response 

(EPER) 

This bit allows a SCSI function of the 
SYM53C876 to detect parity errors on the 
PCI bus and report these errors to the system. 
Only data parity checking is enabled and dis¬ 
abled with this bit. The SYM53C876 always 
generates parity for the PCI bus. 

Bit 5 Reserved 

Bit 4 Write and Invalidate Enable (WIE) 

This bit allows a SCSI function of the 
SYM53C876 to generate write and invalidate 
commands on the PCI bus. Set theWRIE bit 
in the CTEST3 register also for the SCSI 
function to generate write and invalidate com¬ 
mands. 

Bit 3 Reserved 


Bit 2 Enable Bus Mastering (EBM) 

This bit controls the ability of a SCSI fimction 
to act as a master on the PCI bus. A value of 
zero disables this device from generating PCI 
bus master accesses. A value of one allows the 
SCSI fimction to behave as a bus master. When 
the SCSI function is a bus master it can fetch 
SCRIPTS instructions and transfer data. 

Bit 1 Enable Memory Space (EMS) 

This bit controls the ability of a SCSI function 
to respond to Memory space accesses. A value 
of zero disables the device response. A value of 
one allows a SCSI function of the 
SYM53C876 to respond to Memory Space 
accesses at the address range specified by the 
Base Address One and Base Address Two regis¬ 
ters in the SCSI function’s PCI configuration 
space. 

Bit 0 Enable I/O Space (EIS) 

This bit controls a SCSI function’s response to 
I/O space accesses. A value of zero disables the 
device response. A value of one allows a SCSI 
function to respond to I/O Space accesses at 
the address range specified by the Base 
Address Zero register in the SCSI ftmction’s 
PCI configuration space. 
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Register 06h 

Status 

ReadlWrite 


DPE 

SSE 

RMA 

RTA 

RES 

DT 

DPR 

1 RES 

15 

14 

13 

12 

11 

10-9 

8 

7-0 

Default »> 

0 0 

0 

0 

0 

0 

0 

0 


Reads to this register behave normally. Writes are 
slightly different in that bits can be cleared, but not 
set. A bit is reset whenever the register is written, 
and the data in the corresponding bit location is a 
one. For instance, to clear bit 15 and not affect any 
other bits, write the value SOOOh to the register. 

Bit 15 Detected Parity Error (DPE) 

(from Slave) 

This bit is set by the a SCSI function of the 
SYM53C876 whenever it detects a data parity 
error, even if data parity error handling is dis¬ 
abled. 

Bit 14 Signaled System Error (SSE) 

This bit is set whenever the device asserts the 
SERR/ signal. 

Bit 13 Received Master Abort (RMA) 

(from Master) 

A master device should set this bit whenever its 
transaction (except for Special Cycle) is termi¬ 
nated with Master Abort. 

Bit 12 Received Target Abort (RTA) 

(from Master) 

A master device should set this bit whenever its 
transaction is terminated by target-abort. 

Bit 11 Reserved 


Bits 10-9 DEVSEL/Timing (DT) 

These bits encode the timing of DEVSEL/. 
These are encoded as 00b for fast, 01b for 
medium, 10b for slow, and lib reserved. 
These bits are read-only and should indicate 
the slowest time that a device asserts DEVSEL/ 
for any bus command except Configuration 
Read and Configuration Write. In the SCSI 
functions of the SYM53C876, 01b is sup¬ 
ported. 

Bit 8 Data Parity Reported(DPR) 

This bit is set when the following conditions 
are met: 

1. The bus agent asserted PERR/ itself or 
observed PERR/ asserted; 

2. The agent setting this bit acted as the bus 
master for the operation in which the error 
occurred; 

3. The Parity Error Response bit in the 
Command Register is set. 

Bits 7-0 Reserved 
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Register 08h 
Revision ID 
Read Only 


RID 

RID 

RID 

RID 

RID 

RID 

RID 

RID 

7 

6 

5 

4 

3 

2 

1 

0 

Default >» 

0 0 

0 

1 

X 

X 

X 

X 


Register 09h 
Class Code 
Read Only 


cc 

CC 


CC 

CC 

CC 

23-20 

19-16 

MBM 

11-8 

7-4 

3-0 

Default >» 

0 

1 

0 

0 

0 

0 


This field specifies device and revision identifiers. 
In the SYM53C876j the upper nibble is Olh.The 
lower nibble reflects the current revision level of 
the device. It should have the same value as the 
Chip Revision Level bits in the CTEST3 register. 


This register is used to identify the generic func¬ 
tion of the device. The upper byte of this register is 
a base class code, the middle byte is a subclass 
code, and the lower byte identifies a specific regis¬ 
ter-level programming interface. The value of this 
register is OlOOOOh, which identifies a SCSI con¬ 
troller. 
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Register OCh 
Cacheline Size 
Read/Write 


CIS 


mmm 

CIS 



CIS 

CIS 

7 

a 

■n 

4 

m 

m 

1 

0 

Default »> 

0 0 

0 

0 

0 

0 

0 

0 


This register specifies the system cacheline size in 
units of 32-bit words. The value in this register is 
used by the device to determine whether to use 
Write and Invalidate or Write commands for per¬ 
forming write cycles, and whether to use Read, 
Read Line, or Read Multiple commands for per¬ 
forming read cycles as a bus master. Devices par¬ 
ticipating in the caching protocol use this field to 
know when to retry burst accesses at cacheline 
boundaries. These devices can ignore the PCI 
cache support lines (SDONE and SBO#) when 
this register is set to 0. If this register is pro¬ 
grammed to a number which is not a power of 2, 
the device does not use PCI performance com¬ 
mands to perform data transfers. 


Register ODh 
Latency Timer 
ReadI Write 


LT 

LT 

LT 

WM 

LT 

LT 

LT 

LT 

7 

6 

5 

a 

3 

2 

1 

0 

Default »> 

0 0 

0 

0 

0 

0 

0 

0 


The Latency Timer register specifies, in units of 
PCI bus clocks, the value of the Latency Timer for 
this PCI bus master. The SCSI functions of the 
SYM53C876 support this timer. All eight bits are 
writable, allowing latency values of 0-255 PCI 
clocks. Use the following equation to calculate an 
optimum latency value for the SCSI functions of 
the SYM53C876. 

Latency=2+(Burst Size * (typical wait states +1)) 
Values greater than optimum are also acceptable. 
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Register OEh 
Header Type 
Read Only 


HT 

HT 

7-4 

3-0 

Default »> 

8 

0 


This register identifies the layout of bytes 1 Oh 
through 3Fh in configuration space and also 
whether or not the device contains multiple func¬ 
tions. Since the SYM53C876 is a multi-function 
controller, the value of this register is 80h. 


Register OFh 
BIST 
Read Only 


BIST Capable 

Start BIST 


Completion 

Code 

7 

6 

5-4 

3-0 

Default »> 

0 

0 

00 

0000 


This register is used for control and status of BIST. 
Since the SYM53C876 does not support BIST, 
this register is read-only and always returns a value 
of OOh. 
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Register lOh 

Base Address Zero (I/O) 

Read/Write 


BAZ 


BAZ 

I BAZ I 


BAZ 

BAZ 

BAZ 

31-28 


23-20 



11-8 

7-4 

3-0 

Default »> 

X X 

X 

X 

X 

X 

X 

xxxl 


This 32-bit register has bit zero hardwired to one. 
Bit 1 is reserved and returns a zero on all reads, 
and the other bits are used to map the device into 
I/O space. For detailed information on the opera¬ 
tion of this register, refer to the PCI specification. 
This Base Address Zero register maps SCSI oper¬ 
ating registers into I/O space. 


Register 14h 

Base Address One (Memory) 
ReadlWrite 


BAD 

BAD 

BAD 

BAD 

BAD 

BAD 

BAD 

BAD 

31-28 

27-24 

23-20 

19-16 

15-12 

11-8 

7-4 

3-0 

Default »> 

X X 

X 

X 

X 

X 

X 

XXXO 


This register has bit zero hardwired to zero. For 
detailed information on the operation of this regis¬ 
ter, refer to the PCI specification. This Base 
Address One register maps SCSI operating regis¬ 
ters into memory space. 
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Register 18h 

Base Address Two (Memory) 
ReadlWrite 


BAT 

BAT 

I BAT I 

BAT 

BAT 

BAT 

BAT 

1 bat I 

31-28 

27-24 


19-16 

15-12 

11-8 

7-4 


Default »> 

X X 

X 

X 

X 

X 

X 

xxxo 


This register has bit zero hardwired to zero. The 
other bits are used to map the 4 KB SCRIPTS 
RAM into memory space. This register is enabled 
only if the internal SCRIPTS RAM is enabled. 
The internal SCRIPTS RAM is disabled by con¬ 
necting a 4.7 KQ resistor between MADS and 
grotmdj which is sensed immediately after a chip 
reset. SCRIPTS RAM is also disabled by setting 
the Enable Memory Space bit to zero in the SCSI 
PCI Configuration Command register, bit 1. 

If MADS is left unconnected, an internal pull-up 
enables the SCRIPTS RAM and this Base Address 
register. 

If enabled, as with all Base Address registers, ini¬ 
tialize this Base Address register to a value that 
does not conflict with other memory resources. 
Otherwise, memory conflicts may occur. 

For detailed information on the operation of this 
register, refer to the PCI specification. 


Register 2Ch 
Subsystem Vendor ID 
Read Only 


SVID 



SVID 

15-12 


■BH 

3-0 


If EEPROM not enabled «<Default»> 

0 0 0 0 


EEPROM value if EEPROM enabled «<Defaulb» 

X X X X 

This register is used to uniquely identify the ven¬ 
dor manufacturing the add-in board or subsystem 
where this PCI device resides. It provides a mecha¬ 
nism for an add-in card vendor to distinguish its 
cards from another vendor’s cards, even if the 
cards have the same PCI controller installed on 
them (and therefore the same Vendor ID and 
Device ID). See the Serial EEPROM Interface sec¬ 
tion in Chapter 2 for information about the values 
to load in this register. 
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Register 2Eh 
Subsystem ID 
Read Only 



SID 


SID 


11-8 


3-0 


If EEPROM not enabled «<Default»> 

0 0 0 0 


EEPROM value if EEPROM enabled «<Default»> 

X X X X 

This register is used to uniquely identify the add-in 
board or subsystem where this PCI device resides. 
It provides a mechanism for an add-in card vendor 
to distinguish its cards from one another even if the 
cards have the same PCI controller installed on 
them (and therefore the same Vendor ID and 
Device ID). See the Serial EEPROM Interface sec¬ 
tion in Chapter 2 for information about the values 
to load in this register. 


Register 30h 

Expansion ROM Base Address 
ReadlWrite 


ERBA 

ERBA 

1 ERBA 1 

ERBA 

ERBA 

ERBA 

ERBA 

ERBA 

31-28 

27-24 


19-16 

15-12 

11-8 

7-4 

3-0 

Default»> 

0 0 

0 

0 

0 

0 

0 

0 


This four-byte register handles the base address 
and size information for the expansion ROM. It 
functions exactly like the Base Address registers, 
except that the encoding of the bits is different. 
The upper 21 bits correspond to the upper 21 bits 
of the expansion ROM base address. 

The expansion ROM Enable bit, bit 0, is the only 
bit defined in this register. This bit is used to con¬ 
trol whether or not the device accepts accesses to 
its expansion ROM, When the bit is set, address 
decoding is enabled, and a device is used with or 
without an expansion ROM depending on the sys¬ 
tem configuration. To access the external memory 
interface, also set the Memory Space bit in the 
Command register. 

The host system detects the size of the external 
memory by first writing the Expansion ROM Base 
Address register with all ones and then reading 
back the register. The SCSI functions of the 
SYM53C876 respond with zeroes in all don’t care 
locations. The ones in the remaining bits represent 
the binary version of the external memory size. For 
example, to indicate an external memory size of 32 
KB, this register, when written with ones and read 
back, returns ones in the upper 17 bits. 

The ROM is accessed through the MAD bus 
which is common to both SCSI functions in this 
device. 
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Register 3Ch 
Interrupt Line 
ReadlWrite 


IL 

IL 

IL 

■■ 

IL 

IL 

IL 

IL 

7 

6 

5 

B 

3 

2 

1 

0 

Default »> 

0 0 

0 

0 

0 

0 

0 

0 


This register is used to communicate interrupt line 
routing information. POST software writes the 
routing information into this register as it config¬ 
ures the system. The value in this register tells 
which input of the system interrupt controller(s) 
the device’s interrupt pin is connected to. Values in 
this register are specified by system architecture. 


Register 3Dh 
Interrupt Pin 
Read Only 


IP 

IP 

IP 

■9 

IP 

IP 

mgm 

1 IP 1 

7 

6 

5 

B 

3 

2 

B 



SCSI Function A «<Default »> 


0 0 0 0 0 0 0 1 

SCSI Function B if MAD(4) pulled low «<Default »> 

0 0 0 0 0 0 0 1 

SCSI Function B if MAD(4) not pulled low «<Default »> 

0 0 0 0 0 0 1 0 

This register is imique to each SCSI function. It 
tells which interrupt pin the device uses. Its value 
is set to Olh for the Function AINTA/ signal, and 
02h for the Fvmction B INTB/ signal at power-up. 
The Function B INTB/ value is set to Olh if 
MAD (4) is pulled low. 
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Register 3Eh 
Min_Gnt 
Read Only 


MG 

MG 

MG 

MG 

MG 

MG 

MG 

MG 

7 

6 

5 

4 

3 

2 

1 

0 

Default »> 

0 0 

0 

1 

0 

0 

0 

1 


This register is used to specify the desired settings 
for latency timer values. Min_Gnt is used to spec¬ 
ify how long a burst period the device needs. The 
value specified in these registers is in units of 0.25 
microseconds. The SYM53C876 SCSI function 
sets this register to 1 Ih. 


Register 3Fh 
Max_Lat 
Read Only 


ML 

mjAm 

ML 

■Mj 

ML 

ML 

ML 

ML 

7 

6 

5 

n 

3 

2 

1 

0 

Default »> 

0 1 

0 

0 

0 

0 

0 

0 


This register is used to specify the desired settings 
for latency timer values. Max_Lat is used to specify 
how often the device needs to gain access to the 
PCI bus. The value specified in these registers is in 
units of 0.25 microseconds. The SYM53C876 
SCSI function sets this register to 40h. 
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SCSI Registers 

This section contains descriptions of all 
SYM53C876 SCSI registers. Table 4-2 summa¬ 
rizes the SYM53C876 operating register set.Table 
4-3j the register map, lists registers by operating 
and configuration addresses. The terms “set” and 
“assert” are used to refer to bits that are pro¬ 
grammed to a binary one. Similarly, the terms 
“deassertj” “clear” and “reset” are used to refer to 
bits that are programmed to a binary zero. Write 
any bits marked as reserved to zero; mask all infor¬ 
mation read from them. Reserved bit functions 
may change at any time. Unless otherwise indi¬ 
cated, all bits in registers are active high, that is. 


the feature is enabled by setting the bit. The bot¬ 
tom row of every register diagram shows the 
default register values, which are enabled after the 
chip is powered on or reset. 

Note: The only register that the host CPU can 
access while the SYM53C876 is executing 
SCRIPTS is the ISTAT register; attempts 
to access other registers interferes with the 
operation of the chip. However, all 
operating registers are accessible with 
SCRIPTS. All read data is synchronized 
and stable when presented to the PCI bus. 
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Table 4-2: SCSI Operating Register Addresses and Descriptions 


Memory or I/O 
Address 

Read/Write 

Label 

Description 

00 

R/W 

SCNTLO 

SCSI Control 0 

01 

R/W 

SCNTLl 

SCSI Control 1 

02 

R/W 

SCNTL2 

SCSI Control 2 

03 

R/W 

SCNTL3 

SCSI Control 3 

04 

R/W 

SCID 

SCSI Chip ID 

05 

R/W 

SXFER 

SCSI Transfer 

06 

R/W 

SDID 

SCSI Destination ID 

07 

R/W 

GPREG 

General Purpose Bits 

08 

R/W 

SFBR 

SCSI First Byte Received 

09 

R/W 

SOCL 

SCSI Output Control Latch 

OA 

R 

SSID 

SCSI Selector ID 

OB 

Rm 

SBCL 

SCSI Bus Control Lines 

OC 

R 

DSTAT 

DMA Status 

OD 

R 

SSTATO 

SCSI Status 0 

OE 

R 

SSTATl 

SCSI Status 1 

OF 

R 

SSTAT2 

SCSI Status 2 

10-13 

R/W 

DSA 

Data Structure Address 

14 

R/W 

ISTAT 

Interrupt Status 

18 

R/W 

CTESTO 

Reserved 

19 

R/W 

CTESTl 

Chip Test 1 

lA 

R 

CTEST2 

Chip Test 2 

IB 

R 

CTEST3 

Chip Test 3 

IC-IF 

R/W 

TEMP 

Temporary Register 

20 

R/W 

DFIFO 

DMA FIFO 

21 

R/W 

CTEST4 

Chip Test 4 

22 

RJW 

CTEST5 

Chip Test 5 

23 

R/W 

CTEST6 

Chip Test 6 

24-26 

R/W 

DBG 

DMA Byte Counter 

27 

R/W 

DCMD 

DAIA Command 

28-2B 

R/W 

DNAD 

DMA Next Address for Data 

2C-2F 

R/W 

DSP 

DMA SCRIPTS Pointer 

30-33 

R/W 

DSPS 

DMA SCRIPTS Pointer Save 

34-37 

R/W 

SCRATCHA 

General Purpose Scratch Pad A 

38 

R/W 

DMODE 

DMA Mode 

39 

R/W 

DIEN 

DMA Interrupt Enable 

3A 

R/W 

SBR 

Scratch Byte Register 
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Table 4-2: SCSI Operating Register Addresses and Descriptions (Continued) 


Memory or I/O 
Address 

Read/Write 

Label 

Description 

3B 

R/W 

DCNTL 

DMA Control 

3C-3F 

R 

ADDER 

Sum output of internal adder 

40 

R/W 

SIENO 

SCSI Interrupt Enable 0 

41 

R/W 

SIENl 

SCSI Interrupt Enable 1 

42 

R 

SISTO 

SCSI Interrupt Status 0 

43 

R 

SISTl 

SCSI Interrupt Status 1 

44 

R/W 

SLPAR 

SCSI Longitudinal Parity 

45 

R 

SWIDE 

SCSI Wide Residue Data 

46 

R/W 

MACNTL 

Memory Access Control 

47 

R/W 

GPCNTL 

General Purpose Control 

48 

R/W 

STIMEO 

SCSI Timer 0 

49 

R/W 

STIMEl 

SCSI Timer 1 

4A 

R/W 

RESPIDO 

Response ID 0 

4B 

R/W 

RESPIDl 

Response ID 1 

4C 

R 

STESTO 

SCSI Test 0 

4D 

R 

STESTl 

SCSI Test 1 

4E 

R/W 

STEST2 

SCSI Test 2 

4F 

R/W 

STEST3 

SCSI Test 3 

50-51 

R 

SIDE 

SCSI Input Data Latch 

52-53 



Reserved 

54-55 

R/W 

SODL 

SCSI Output Data Latch 

56-57 



R^erved 

58-59 

R 

SBDL 

SCSI Bus Data Lines 

5A-5B 



Reserved 

5C-5F 

R/W 

SCRATCHB 

General Purpose Scratch Pad B 

60-7F 

R/W 

SCRATCHC-J 

General Purpose Scratch Pad C-J 


SYM53C876 Data Manual 


4-15 




Registers 

SCSI Registers 


PREUMINARY 


Table 4-3: SYM53C876 SCSI Register Address Map 



Mem i/0 

SCNTL3 

SCNTL2 

SCNTLl 

SCNTLO 

00 

GPREG 

SDID 

SXFER 

SCID 

04 

SBCL 

SSID 

SOCL 

SFBR 

08 

SSTAT2 

SSTATl 

SSTATO 

DSTAT 

OC 

DSA 

10 

Reserved 

ISTAT 

14 

CTEST3 

CTEST2 

CTESTl 

CTESTO 

18 

TEMP 

1C 

CTEST6 

CTEST5 

CTEST4 

DFIFO 

20 

DCMD 

DBG 

24 

DNAD 

28 

DSP 

2C 

DSPS 

30 

SCRATCHA 

34 

DCNTL 

SBR 

DIEN 

DMODE 

38 

AD] 

DER 

3C 

SISTl 

SISTO 

SIENl 

SIENO 

40 

GPCNTL 

MACNTL 

SWIDE 

SLPAR 

44 

RESPIDl 

RESPIDO 

STIMEl 

STI2V1E0 

48 

STEST3 

STEST2 

STESTl 

STESTO 

4C 

Reserye^''^^ - V.' 

SI] 

DL 

50 


SODL 

54 


SBDL 

58 

SCRATCHB 

5C 

SCRATCHC 

60 

SCRATCHD 

64 

SCRATCHE 

68 

SCRATCHF 

6C 

SCRATCHG 

70 

SCRATCHH 

74 

SCRATCHI 

78 

SCRATCH! 

7C 
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Register OOh 

SCSI Control Zero (SCNTLO) 

ReadlWrite 


ARBI 

ARBO 

STAR 

T 

WATN 

EPC 

si S s 

AAP 

TRG 

7 

6 

5 

4 

3 

2 

1 

0 

Default »> 

1 1 

0 

0 

0 

X 

0 

0 


Bit 7 ARBI (Arbitration Mode bit 1) 
Bit 6 ARBO (Arbitration Mode bit 0) 


ARBI ARBO Arbitration Mode 


0 

0 

Simple arbitration 

0 

1 

Reserved 

1 

0 

Reserved 

1 

1 

Full arbitration, selection/reselection 


Simple Arbitration 

1. The SYM53C876 SCSI function waits for a 
bus free condition to occur. 

2. It asserts SBSY/ and its SCSI ID (contained in 
the SCID register) onto the SCSI bus. If the 
SSEL/ signal is asserted by another SCSI 
device, the SYM53C876 SCSI function 
deasserts SBSY/, deasserts its ID and sets the 
Lost Arbitration bit (bit 3) in the SSTATO 
register. 

3. After an arbitration delay, the CPU should 
read the SBDL register to check if a higher 
priority SCSI ID is present. If no higher 
priority ID bit is set, and the Lost Arbitration 
bit is not set, the SYM53C876 SCSI function 
wins arbitration. 

4. Once the SYM53C876 SCSI function wins 
arbitration, assert SSEIV via the SOCL for a 
bus clear plus a bus settle delay (1.2 ps) before 
a low level selection is performed. 


Full Arbitration, Selection/Reselection 

1. The SYM53C876 SCSI function waits for a 
bus free condition. 

2. It asserts SBSY/ and its SCSI ID (the highest 
priority ID stored in the SCID register) onto 
the SCSI bus. 

3. If the SSEL/ signal is asserted by another SCSI 
device or if the SYM53C876 SCSI function 
detects a higher priority ID, the SYM53C876 
SCSI function deasserts BSY, deasserts its ID, 
and waits until the next bus free state to try 
arbitration again. 

4. The SYM53C876 SCSI function repeats 
arbitration until it wins control of the SCSI 
bus. When it wins, the Won Arbitration bit is 
set in the SSTATO register, bit 2. 

5. The SYM53C876 SCSI function performs 
selection by asserting the following onto the 
SCSI bus: SSEL/, the target’s ID (stored in the 
SDID register), and the SYM53C876’s ID 
(stored in the SCID register). 

6. After a selection is complete, the Function 
Complete bit is set in the SISTO register, bit 6. 

7. If a selection time-out occurs, the Selection 
Time-Out bit is set in the SISTl register, bit 2. 

Bit 5 START (Start Sequence) 

When this bit is set, the SYM53C876 starts the 
arbitration sequence indicated by the Arbitra¬ 
tion Mode bits. The Start Sequence bit is 
accessed directly in low-level mode; during 
SCSI SCRIPTS operations, this bit is con¬ 
trolled by the SCRIPTS processor. Do not 
start an arbitration sequence if the connected 
(CON) bit in the SCNTLl register, bit 4, indi¬ 
cates that the SYM53C876 is already con¬ 
nected to the SCSI bus. This bit is 
automatically cleared when the arbitration 
sequence is complete. If a sequence is aborted, 
check bit 4 in the SCNTLl register to verify 
that the SYM53C876 is not connected to the 
SCSI bus. 
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Bit 4 WATN (Select with SATN/ on a Start 
Sequence) 

When this bit is set and the SYM53C876 SCSI 
function is in initiator mode, the SATN/ signal 
is asserted during selection of a SCSI target 
device. This is to inform the target that the 
SYM53C876 SCSI function has a message to 
send. If a selection time-out occurs while 
attempting to select a target device, SATN/ is 
deasserted at the same time SSEL/ is deas- 
serted. When this bit is clear, the SATN/ signal 
is not asserted during selection. When execut¬ 
ing SCSI SCRIPTS, this bit is controlled by 
the SCRIPTS processor, but manual setting is 
possible in low level mode. 

Bit 3 EPC (Enable Parity Checking) 

When this bit is set, the SCSI data bus is 
checked for odd parity when data is received 
from the SCSI bus in either initiator or target 
mode. If a parity error is detected, bit 0 of the 
SISTO register is set and an interrupt may be 
generated. 

If the SYM53C876 SCSI function is operating 
in initiator mode and a parity error is detected, 
assertion of SATN/ is optional, but the transfer 
continues until the target changes phase. When 
this bit is cleared, parity errors are not 
reported. 

Bit 2 Reserved 


Bit 1 AAP (Assert SATN/ on Parity Error) 

When this bit is set, the SYM53C876 SCSI 
function automatically asserts the SATN/ sig¬ 
nal upon detection of a parity error. SATN/ is 
only asserted in initiator mode. The SATN/ 
signal is asserted before deasserting SACK/ 
during the byte transfer with the parity error. 
Also set the Enable Parity Checking bit for the 
SYM53C876 SCSI function to assert SATN/ 
in this manner. A parity error is detected on 
data received from the SCSI bus. 

If the Assert SATN/ on Parity Error bit is 
cleared or the Enable Parity Checking bit is 
cleared, SATN/ is not automatically asserted 
on the SCSI bus when a parity error is 
received. 

Bit 0 TRG (Target Mode) 

This bit determines the default operating mode 
of the SYM53C876 SCSI function. The user 
must manually set target or initiator mode. 
This is done using the SCRIPTS language 
(SETTARGET or CLEAR TARGET). When 
this bit is set, the chip is a target device by 
default. When this bit is cleared, the 
SYM53C876 SCSI function is an initiator 
device by default. 

CAUTION: 

Writing this bit while not connected may cause the 
loss of a selection or reselection due to the chang¬ 
ing of target or initiator modes. 
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Register Olh 

SCSI Control One (SCNTLl) 
Read! Write 


EXC 

ADB 

DHP 

CON 

RST 

AESP 

lARB 

SST 

7 

6 

5 

4 

3 

2 

1 

0 

Default »> 

0 0 

0 

0 

0 

0 

0 

0 


Bit 7 EXC (Extra Clock Cycle of Data 
Setup) 

When this bit is set, an extra clock period of 
data setup is added to each SCSI send data 
transfer. The extra data setup time can provide 
additional system design margin, though it 
affects the SCSI transfer rates. Clearing this bit 
disables the extra clock cycle of data setup 
time. Setting this bit only affects SCSI send 
operations. 

Bit 6 ADB (Assert SCSI Data Bus) 

When this bit is set, the SYM53C876 SCSI 
function drives the contents of the SCSI Out¬ 
put Data Latch Register (SODL) onto the 
SCSI data bus. When the SYM53C876 SCSI 
function is an initiator, the SCSI I/O signal 
must be inactive to assert the SODL contents 
onto the SCSI bus. When the SYM53C876 
SCSI function is a target, the SCSI I/O signal 
must be active to assert the SODL contents 
onto the SCSI bus. The contents of the SODL 
register can be asserted at any time, even 
before the SYM53C876 SCSI function is con¬ 
nected to the SCSI bus. Clear this bit when 
executing SCSI SCRIPTS. It is normally used 
only for diagnostics testing or operation in low 
level mode. 

Bit 5 DHP (Disable Halt on Parity Error or 
ATN) (Target Only) 

The DHP bit is only defined for target mode. 
When this bit is cleared, the SYM53C876 
SCSI function halts the SCSI data transfer 
when a parity error is detected or when the 
SATN/ signal is asserted. If SATN/ or a parity 
error is received in the middle of a data trans¬ 


fer, the SYM53C876 SCSI function may 
transfer up to three additional bytes before 
halting to synchronize between internal core 
cells. During synchronous operation, the 
SYM53C876 SCSI function transfers data 
until there are no outstanding synchronous off¬ 
sets. If the SYM53C876 SCSI function is 
receiving data, any data residing in the DMA 
FIFO is sent to memory before halting. 

When this bit is set, the SYM53C876 SCSI 
function does not halt the SCSI transfer when 
SATN/ or a parity error is received. 

Bit 4 CON (Connected) 

This bit is automatically set any time the 
SYM53C876 SCSI function is connected to 
the SCSI bus as an initiator or as a target. It is 
set after the SYM53C876 SCSI function suc¬ 
cessfully completes arbitration or when it has 
responded to a bus initiated selection or rese¬ 
lection. This bit is also set after the chip wins 
simple arbitration when operating in low level 
mode. When this bit is clear, the SYM53C876 
SCSI function is not connected to the SCSI 
bus. 

The CPU can force a connected or discon¬ 
nected condition by setting or clearing this bit. 
This feature is used primarily during loopback 
mode. 

Bit 3 RST (Assert SCSI RST/ Signal) 

Setting this bit asserts the SRST/ signal. The 
SRST/ output remains asserted until this bit is 
cleared. The 25 ps minimum assertion time 
defined in the SCSI specification must be 
timed out by the controlling microprocessor or 
a SCRIPTS loop. 

Bit 2 AESP (Assert Even SCSI Parity 
(force bad parity)) 

When this bit is set, the SYM53C876 SCSI 
function asserts even parity. It forces a SCSI 
parity error on each byte sent to the SCSI bus 
from the chip. If parity checking is enabled, 
then the SYM53C876 SCSI function checks 
data received for odd parity. This bit is used for 
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diagnostic testing and is cleared for normal 
operation. It is useful to generate parity errors 
to test error handling functions. 

Bit 1 lARB (Immediate Arbitration) 

Setting this bit causes the SCSI core to imme¬ 
diately begin arbitration once a Bus Free phase 
is detected following an expected SCSI discon¬ 
nect. This bit is useful for multi-threaded appli¬ 
cations. The ARB 1-0 bits in SCNTLO is set for 
full arbitration and selection before setting this 
bit. 

Arbitration is re-tried until won. At that point, 
the SYM53C876 SCSI function holds BSY 
and SEL asserted, and waits for a select or 
reselect sequence. The Immediate Arbitration 
bit is reset automatically when the selection or 
reselection sequence is completed, or times 
out. During the time between the assertion of 
the lARB bit and the completion of a Perform 
Select/Reselect instruction, DMA interrupts 
are disabled. Therefore, interrupt instructions 
placed between the assertion of the lARB bit 
and the Perform Select/Reselect instruction are 
not executed. 

An unexpected disconnect condition clears 
lARB without attempting arbitration. See the 
SCSI Disconnect Unexpected bit (SCNTL2, 
bit 7) for more information on expected versus 
unexpected disconnects. 

It is possible to abort an immediate arbitration 
sequence. First, set the Abort bit in the ISTAT 
register. Then one of two things eventually 
happens: 

1. The Won Arbitration bit (SSTATO bit 2) is set. 
In this case, the Immediate Arbitration bit 
needs to be reset. This completes the abort 
sequence and disconnects the chip from the 
SCSI bus. If it is not acceptable to go to Bus 
Free phase immediately following the 
arbitration phase, it is possible to perform a 
low level selection instead. 

2. The abort completes because the SYM53C876 
SCSI function loses arbitration. This is 


detected by the clearing of the Immediate 
Arbitration bit. Do not use the Lost Arbitration 
bit (SSTATO bit 3) to detect this condition. In 
this case take no further action. 

Bit 0 SST (Start SCSI Transfer) 

This bit is automatically set during SCRIPTS 
execution. It causes the SCSI core to begin a 
SCSI transfer, including SREQ/SACK hand¬ 
shaking. The determination of whether the 
transfer is a send or receive is made according 
to the value written to the I/O bit in SOCL. 
This bit is self-resetting. Do not set it for low 
level operation. 

CAUTION: 

Writing to this register while not connected may 
cause the loss of a selection/reselection by resetting 
the Connected bit. 
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Register 02h 

SCSI Control Two (SCNTL2) 
ReadlWrite 


SDU 

CHM 

SLPM 

D 

SLPH¬ 

BEN 

WSS 

VUEO 

VUE1 

WSR 

7 

6 

5 

4 

3 

2 

1 

0 


Default »> 

000 0 00X0 


Bit 7 SDU (SCSI Disconnect Unexpected) 

This bit is valid in initiator mode only. When 
this bit is set, the SCSI core is not expecting 
the SCSI bus to enter the Bus Free phase. If it 
does, an unexpected disconnect error is gener¬ 
ated (see the Unexpected Disconnect bit in the 
SISTO register, bit 2). During normal 
SCRIPTS mode operation, this bit is set auto¬ 
matically whenever the SCSI core is reselected, 
or successfully selects another SCSI device. 
The SDU bit should be reset with a register 
write (MOVE 0X00 TO SCNTL2) before the 
SCSI core expects a disconnect to occur, nor¬ 
mally prior to sending an Abort, Abort Tag, 
Bus Device Reset, Clear Queue or Release 
Recovery message, or before deasserting 
SACK/ after receiving a Disconnect command 
or Command Complete message. 

Bit 6 CHM (Chained Mode) 

This bit determines whether or not the SCSI 
core is programmed for chained SCSI mode. 
This bit is automatically set by the Chained 
Block Move (CHMOV) SCRIPTS instruction 
and is automatically cleared by the Block Move 
SCRIPTS instruction (MOVE). 

Chained mode is primarily used to transfer 
consecutive wide data blocks. Using chained 
mode facilitates partial receive transfers and 
allows correct partial send behavior. When this 
bit is set and a data transfer ends on an odd 
byte boundary, the SYM53C876 SCSI func¬ 
tion stores the last byte in the SCSI Wide Resi¬ 
due Data Register during a receive operation, 
or in the SCSI Output Data Latch register dur¬ 
ing a send operation. This byte is combined 
with the first byte from the subsequent transfer 


so that a wide transfer are completed. 

For more information, see the “Chained 
Mode” section in Chapter 2, “Functional 
Description.” 

Bit 5 SLPMD (SLPAR Mode Bit) 

If this bit is clear, the SLPAR register functions 
as a byte-wide longitudinal parity register. If 
this bit is set, the SLPAR functions as a word¬ 
wide longitudinal parity function. The high or 
low byte of the SLPAR word is accessible 
through the SLPAR register. Which byte is 
accessible is controlled by the SLPHBEN bit. 

Bit 4 SLPHBEN (SLPAR High Byte 
Enable) 

If this bit is clear, the low byte of the SLPAR 
word is present in the SLPAR register. If this 
bit is set, the high byte of the SLPAR word is 
present in the SLPAR register. 

Bit 3 WSS (Wide SCSI Send) 

When read, this bit returns the value of the 
Wide SCSI Send (WSS) flag. Asserting this bit 
clears the WSS flag. This clearing function is 
self-resetting. 

When the WSS flag is high following a wide 
SCSI send operation, the SCSI core is holding 
a byte of “chain” data in the SODL register. 
This data becomes the first low-order byte sent 
when married with a high-order byte during a 
subsequent data send transfer. 

Performing a SCSI receive operation clears this 
bit. Also, performing any non-wide transfer 
clears this bit. 

Bit 2 VUEO (Vendor Unique Enhancement 
bit 0) 

This bit is a read only value indicating whether 
the group code field in the SCSI instruction is 
standard or vendor unique. If reset, the bit 
indicates standard group codes; if set, the bit 
indicates vendor unique group codes. The 
value in this bit is reloaded at the beginning of 
all asynchronous target receives. 
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Bit 1 VUEl (Vendor Unique Enhancement 
bit 1) 

This bit is used to disable the automatic byte 
count reload during Block Move instructions 
in the command phase. If this bit is reset, the 
device reloads the Block Move byte count if the 
first byte received is one of the standard group 
codes. If this bit is set, the device does not 
reload the Block Move byte coimt, regardless 
of the group code. 

Bit 0 WSR (Wide SCSI Receive) 

When read, this bit returns the value of the 
Wide SCSI Receive (WSR) flag. Setting this 
bit clears the WSR flag. This clearing function 
is self-resetting. 

The WSR flag indicates that the SCSI core 
received data from the SCSI bus, detected a 
possible partial transfer at the end of a chained 
or non-chained block move command, and 
temporarily stored the high-order byte in the 
SWIDE register rather than passing the byte 
out the DMA channel. The hardware uses the 
WSR status flag to determine what behavior 
must occur at the start of the next data receive 
transfer. When the flag is set, the stored data in 
SWIDE may be “residue” data, valid data for a 
subsequent data transfer, or overrun data. The 
byte is read as normal data by starting a data 
receive transfer. 

Performing a SCSI send operation clears this 
bit. Also, performing any non-wide transfer 
clears this bit. 


Register 03h 

SCSI Control Three (SCNTL3) 
ReadlWrite 


USE 

SCF2 

SCF1 

SCFO 

EWS 

CCF2 

CCF1 

CCFO 

7 

6 

5 

4 

3 

2 

1 

0 

Default »> 

0 0 

0 

0 

0 

0 

0 

0 


Bit 7 USE (Ultra SCSI Enable) 

Setting this bit enables Ultra SCSI synchro¬ 
nous transfers. The default value of this bit is 0. 
Set this bit only when the transfer rate exceeds 
10 Mega-transfers/sec. 

When this bit is set, the signal filtering period 
for SREQ/ and SACK/ automatically changes 
to 15 ns, regardless of the value of the Extend 
REQ/ACK Filtering bit in the STEST2 regis¬ 
ter. 

Bits 6-4 SCF2-0 (Synchronous Clock 
Conversion Factor) 

These bits select a factor by which the fre¬ 
quency of SCLK is divided before being pre¬ 
sented to the synchronous SCSI control logic. 
Write these to the same value as the Clock 
Conversion Factor bits below unless fast SCSI 
operation is desired. See the SCSI Transfer 
(SXFER) register description for examples of 
how the SCF bits are used to calculate syn¬ 
chronous transfer periods. See the table under 
the description of bits 7-5 of the SXFER regis¬ 
ter for the valid combinations. 

Note: For additional information on how the 
synchronous transfer rate is determined, 
refer to Chapter 2, “Functional Description” 
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Bit 3 EWS (Enable Wide SCSI) 

When this bit is clear, all information transfer 
phases are assumed to be eight bits, transmit¬ 
ted on SD7-0/, SDPO/. When this bit is 
asserted, data transfers are done 16 bits at a 
time, with the least significant byte on SD7-0/, 
SDP/ and the most significant byte on 
SD15-8/, SDPl/. Command, Status, and Mes¬ 
sage phases are not affected by this bit. 

Bits 2-0 CCF2-0 (Clock Conversion Factor) 

These bits select a factor by which the fre¬ 
quency of SCLK is divided before being pre¬ 
sented to the SCSI core. The synchronous 
portion of the SCSI core can be run at a differ¬ 
ent clock rate for fast SCSI, using the Synchro¬ 
nous Clock Conversion Factor bits. The bit 
encoding is displayed in the table below. All 
other combinations are reserved. 


SCF2 

CCF2 

SCF1 

CCF1 

SCFO 

CCFO 

Factor 

Frequency 

SCSI Clock 
(MHz) 

0 

0 

0 

SCLK/3 

50.01-75.0 

0 

0 

1 

SCLK/1 

16.67-25.0 

0 

1 

0 

SCLK/1.5 

25.01-37.5 

0 

1 

1 

SCLK/2 

37.51-50.0 

1 

0 

0 

SCLK/3 

50.01-75.0 

1 

0 

1 

SCLK/4 

75.01-80.00 

1 

1 

0 

SCLK/6 

120 

1 

1 

1 

SCLK/8 

160 


Note: It is important that these bits are set to the 
proper values to guarantee that the 
SYM53C876 meets the SCSI timings as 
defined by the ANSI specification. 


Register 04h 

SCSI Chip ID (SCID) 

ReadlWrite 


RES 

RRE 

SRE 

RES 

ENC3 

ENC2 

ENC1 

ENCO 

7 

6 

5 

4 

3 

2 

1 

0 

Default »> 

X 0 

0 

X 

0 

0 

0 

0 


Bit 7 Reserved 

Bit 6 RRE (Enable Response to 

Reselection) 

When this bit is set, the SYM53C876 SCSI 
function is enabled to respond to bus-initiated 
reselection at the chip ID in the RESPIDO and 
RESPIDl registers. Note that the chip does 
not automatically reconfigure itself to initiator 
mode as a result of being reselected. 

Bit 5 SRE (Enable Response to Selection) 

When this bit is set, the SYM53C876 SCSI 
function is able to respond to bus-initiated 
selection at the chip ID in the RESPIDO and 
RESPIDl registers. Note that the chip does 
not automatically reconfigure itself to target 
mode as a result of being selected. 

Bit 4 Reserved 

Bits 3-0 Encoded Chip SCSI ID, bits 3-0 

These bits are used to store the SYM53C876 
SCSI function encoded SCSI ID. This is the 
ID which the chip asserts when arbitrating for 
the SCSI bus. The IDs that the SYM53C876 
SCSI function responds to when selected or 
reselected are configured in the RESPIDO and 
RESPIDl registers. The priority of the 16 pos¬ 
sible IDs, in descending order is: 


Highest 


Lowest 

7 6 5 4 3 2 1 

0 

15 14 13 12 11 10 9 8 
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Register 05h 

SCSI Transfer (SXFER) 

ReadlWrite 


TP2 

TP1 

TPO 

M04 

M03 

M02 

M01 

MOO 

7 

6 

5 

4 

3 

2 

1 

0 

Default »> 

0 0 

0 

X 

0 

0 

0 

0 


Note: When using Table Indirect I/O commands, 
bits 7-0 of this register are loaded from the 
I/O data structure. 

Note: For additional information on how the 
synchronous transfer rate is determined, 
refer to Chapter 2, “Functional 
Description.” 

Bits 7-5 TP2-0 (SCSI Synchronous Transfer 
Period) 

These bits determine the SCSI synchronous 
transfer period used by the SYM53C876 SCSI 
function when sending synchronous SCSI data 
in either initiator or target mode. These bits 
control the programmable dividers in the chip. 

Note: For Wide Ultra SCSI transfers, the ideal 
transfer period is 4, and 5 is acceptable. 
Setting the transfer period to a value 
greater than 5 is not recommended. 


TP2 

TP1 

TPO 

XFERP 

0 

0 

0 

4 

0 

0 

1 

5 

0 

1 

0 

6 

0 

1 

1 

7 

1 

0 

0 

8 

1 

0 

1 

9 

1 

1 

0 

10 

1 

1 

1 

11 


The synchronous transfer period the 
SYM53C876 should use when transferring 
SCSI data is determined as in this exam- 


ple.The SYM53C876 is connected to a hard 
disk which can transfer data at 10 MB/s syn¬ 
chronously. The SYM53C876 SCSI function’s 
SCLK is running at 40 MHz. The synchronous 
transfer period (SXFERP) is found as follows: 

SXFERP = Period/SSCP + ExtCC 

Period = 1 + Frequency = 1 + 10 MB/s = 100 ns 

SSCP = 1 +SSCF = 1 + 40 MHz = 25 ns 

(This SCSI synchronous core clock is determined in SCNTL3 bits 6-4 

ExtCC = 1 if SCNTL1 bit 7 is asserted and the 53C876 is sending data. 

ExtCC = 0 if the 53C876 is receiving data) 

SXFERP = 100+ 25 = 4 
Key: 

SXFERP = Synchronous transfer period 
SSCP = SCSI Synchronous core period 
SSCF = SCSI Synchronous core frequency 
ExtCC = Extra clock cycle of data setup 


Table 4-4: Examples of Synchronous Transfer 
Periods for SCSI-1 Transfer Rates 



SCSI 


Synch. 

Synch. 

CLK 

CLK + 

XFERP 

Transfer 

Transfer 

(MHz) 

SCNTL3 

Period 

Rate 


bits 6-4 


(ns) 

(MB/s) 

40 

+4 

4 

200 

5 

80 

+2 

4 

200 

5 


Table 4-5: Example Transfer periods for Fast 
SCSI and Wide Ultra SCSI transfer rates 


CLK 

(MHz) 

SCSI 
CLKh- 
SCNTL3 
bits 6-4 

XFERP 

Synch. 

Transfer 

Period 

(ns) 

Synch. 

Transfer 

Rate 

(MB/s) 

80 

+1 

4 

50 

20 

80 

*2 

4 

100 

10 

40 

+1 

4 

100 

10 
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Bits 4-0 MO4-MO0 (Max SCSI Synchronous 
Offset) 

These bits describe the maximum SCSI syn¬ 
chronous offset used by the SYM53C876 
SCSI fimction when transferring synchronous 
SCSI data in either initiator or target mode. 
The following table describes the possible 
combinations and their relationship to the syn¬ 
chronous data offset used by the SYM53C876 
SCSI function. These bits determine the 
SYM53C876 SCSI function’s method of 
transfer for Data In and Data Out phases only; 
all other information transfers occur asynchro¬ 
nously. 


M04 

M03 M02 

M01 

MOO 

Synchronous 

Offset 

0 

0 

0 

0 

0 

O-Asynchronous 

0 

0 

0 

0 

1 

1 

0 

0 

0 

1 

0 

2 

0 

0 

0 

1 

1 

3 

0 

0 

1 

0 

0 

4 

0 

0 

1 

0 

1 

5 

0 

0 

1 

1 

0 

6 

0 

0 

1 

1 

1 

7 

0 

1 

0 

0 

0 

8 

0 

1 

0 

0 

1 

9 

0 

1 

0 

1 

0 

10 

0 

1 

0 

1 

1 

11 

0 

1 

1 

0 

0 

12 

0 

1 

1 

0 

1 

13 

0 

1 

1 

1 

0 

14 

0 

1 

1 

1 

1 

15 

1 

0 

0 

0 

0 

16 

1 



Register 06h 

SCSI Destination ID (SDID) 
ReadlWrite 


RES , 


RES 

RES 

ENC3 

ENC2 

ENC1 

ENCO 

7 ; 

'' 

5 

4 

3 

2 

1 

0 

Default »> 

X X 

X 

X 

0 

0 

0 

0 


Bits 7-4 Reserved 

Bits 3-0 Encoded Destination SCSI ID 

Writing these bits sets the SCSI ID of the 
intended initiator or target during SCSI rese¬ 
lection or selection phases, respectively. When 
executing SCRIPTS, the SCRIPTS processor 
writes the destination SCSI ID to this register. 
The SCSI ID is defined by the user in a 
SCRIPTS Select or Reselect instruction. The 
value written is the binary-encoded ID. The 
priority of the 16 possible IDs, in descending 
order, is: 


Highest 


Lowest 

7 6 5 4 3 2 1 

0 

15 14 13 12 11 10 9 8 
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Register 07h 

General Purpose (GPREG) 
Read! Write 



RES 


GPI04 

6PI03 

GPI02 

GPI01 

GPIOO 


6 


4 

3 

2 

1 

0 

Default »> 

X X 

X 

0 

X 

X 

X 

X 


The general purpose register is used to drive and 
sense values on the general purpose I/O pins. If 
both SCSI function GPREG registers define a sin¬ 
gle GPIO pin as an output, the results are indeter¬ 
minate. 

Bits 7-5, 3 Reserved 

Bits 4,2-0 GPIO4-GPIO0 (General Purpose) 

These bits are programmed through the 
GPCNTL register as inputs, outputs, or to 
perform special functions. As an output, these 
pins are used to enable or disable external ter¬ 
minators. It is also possible to program these 
signals as live inputs and sense them through a 
SCRIPTS Register to Register Move Instruc¬ 
tion. GPIO (2-0) default as inputs and GPI04 
defaults as an output pin. When configured as 
inputs, an internal pull-up is enabled. 

It is possible to use GPI04 to enable or disable 
Vpp, the 12-volt power supply to the external 
flash memory. This bit powers up with the 
power to the external memory disabled. 

The Symbios Logic PCI to SCSI host adapters 
use the GPI04 pin in the process of flashing a 
new SDMS ROM. 

Symbios Logic SDMS software uses the 
GPIOO pin to toggle SCSI device LEDs, turn¬ 
ing on the LED whenever the SYM53C876 
SCSI function is on the SCSI bus. SDMS 
drives this pin low to turn on the LED, or 
drives it high to turn off the LED. 

Symbios Logic software also uses the GPIO 1-0 
signals to access serial EEPROM. GPIOl is 
used as a clock, with the GPIOO pin serving as 
data. 


Register 08h 

SCSI First Byte Received (SFBR) 
Read! Write 



Win 

wa 

Wj« 


n|w 

1B1 

muim 

B 

B 

B 

B 

B 

B 

1 

Bi 

Default »> 

0 0 

0 

0 

0 

0 

0 

0 


This register contains the first byte received in any 
asynchronous information transfer phase. For 
example, when a SYM53C876 SCSI function is 
operating in initiator mode, this register contains 
the first byte received in the Message-In, Status, 
and Data-In phases. 

When a Block Move instruction is executed for a 
particular phase, the first byte received is stored in 
this register— even if the present phase is the same 
as the last phase. The first byte received value for a 
particular input phase is not valid imtil after a 
MOVE instruction is executed. 

This register is also the accumulator for register 
read-modify-writes with the SFBR as the destina¬ 
tion. This allows bit testing after an operation. 

The SFBR is not writable via the CPU, and there¬ 
fore not by a Memory Move. However, it can be 
loaded via SCRIPTS Read/Write operations. To 
load the SFBR with a byte stored in system mem¬ 
ory, the byte must first be moved to an intermedi¬ 
ate SYM53C876 SCSI function register (such as 
the SCRATCH register), and then to the SFBR. 

This register also contains the state of the lower 
eight bits of the SCSI data bus during the Selec¬ 
tion phase if the COM bit in the DCNTL register 
is clear. 

If the COM bit is cleared, do not access this regis¬ 
ter via SCRIPTS operation, as non-determinate 
operations may occur. (This includes SCRIPTS 
Read/Write operations and conditional transfer 
control instructions that initialize the SFBR regis¬ 
ter.) 
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Register 09h 

SCSI Output Control Latch (SOCL) 
ReadlWrite 







HBI 

C/D 

I/O 

Di 

m 

HI 


■i 

nn 

1 

0 

Default »> 

0 0 

0 

0 

0 

0 

0 

0 


Bit 7 REQCAssert SCSI REQ/ Signal) 

Bit 6 ACK(Assert SCSI ACK/ Signal) 

Bit 5 BSY(Assert SCSI BSY/ Signal) 

Bit 4 SEL(Assert SCSI SEU Signal) 

Bit 3 ATN(Assert SCSI ATN/ Signal) 

Bit 2 MSG(Assert SCSI MSG/ Signal) 

Bit 1 C/D (Assert SCSI C_D/ Signal) 

Bit 0 I/0(Assert SCSI I_0/ Signal) 

This register is used primarily for diagnostic test¬ 
ing or programmed I/O operation. It is controlled 
by the SCRIPTS processor when executing SCSI 
SCRIPTS. SOCL is used only when transferring 
data via programmed I/O. Some bits are set (1) or 
reset (0) when executing SCSI SCRIPTS. Do not 
write to the register once the SYM53C876 SCSI 
function starts executing normal SCSI SCRIPTS. 


Register OAh 

SCSI Selector ID (SSID) 

Read Only 


VAL 

H ' 


B ■■ 

ENID3 

ENID2 

ENID1 

ENIDO 

7 

$ 



3 

2 

1 

0 

Default »> 

0 X 

X 

X 

0 

0 

0 

0 


Bit 7 VAL (SCSIVaUd) 

IfVAL is asserted, then the two SCSI IDs are 
detected on the bus during a bus-initiated 
selection or reselection, and the encoded desti¬ 
nation SCSI ID bits below are valid. IfVAL is 
deasserted, only one ID is present and the con¬ 
tents of the encoded destination ID are mean¬ 
ingless. 

Bits 6-4 Reserved 

Bits 3-0 Encoded Destination SCSI ID 

Reading the SSID register immediately after 
the SYM53C876 SCSI function is selected or 
reselected returns the binary-encoded SCSI ID 
of the device that performed the operation. 
These bits are invalid for targets that are 
selected under the single initiator option of the 
SCSI-1 specification. This condition is 
detected by examining the VAL bit above. 
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Register OBh 

SCSI Bus Control Lines (SBCL) 

Read Only 







MSG 

C/D 

— 

■1 

B 

B 

B 

B 

2 

1 

B: 

Default »> 

X X 

X 

X 

X 

X 

X 

X 


Bit 7 REQ (SREQ/ Status) 

Bit 6 ACK (SACK/ Status) 

Bit 5 BSY (SBSY/ Status) 

Bit 4 SEL (SSEL/ Status) 

Bit 3 ATN (SATN/ Status) 

Bit 2 MSG (SMSG/ Status) 

Bit 1 C/D (SC_D/ Status) 

Bit 0 I/O (SI_0/ Status) 

This register returns the SCSI control line status. 
A bit is set when the corresponding SCSI control 
line is asserted. These bits are not latched; they are 
a true representation of what is on the SCSI bus at 
the time the register is read. The resulting read 
data is synchronized before being presented to the 
PCI bus to prevent parity errors from being passed 
to the system. This register is used for diagnostics 
testing or operation in low level mode. 


Register OCh 
DMA Status (DSTAT) 
Read Only 



MDPE 

BF 

ABRT 


SIR 


IID 

B 

6 

5 

4 

B 

2 


0 

Default »> 

1 0 

0 

0 

0 

0 

X 

0 


Reading this register clears any bits that are set at 
the time the register is read, but does not necessar¬ 
ily clear the register in case additional interrupts 
are pending (the SYM53C876 SCSI functions 
stack interrupts).The DIP bit in the ISTAT regis¬ 
ter is also cleared. It is possible to mask DMA 
interrupt conditions individually through the 
DIEN register. 

When performing consecutive 8-bit reads of the 
DSTAT, SISTO and SISTl registers (in any 
order), insert a delay equivalent to 12 CLX peri¬ 
ods between the reads to ensure that the interrupts 
clear properly. See Chapter 2, “Functional 
Description,” for more information on interrupts. 

Bit 7 DFE (DMA FIFO Empty) 

This status bit is set when the DMA FIFO is 
empty. It is possible to use it to determine if 
any data resides in the FIFO when an error 
occurs and an interrupt is generated.This bit is 
a pure status bit and does not cause an inter¬ 
rupt. 

Bit 6 IViDPE (Master Data Parity Error) 

This bit is set when the SYM53C876 SCSI 
function as a master detects a data parity error, 
or a target device signals a parity error during a 
data phase. This bit is completely disabled by 
the Master Parity Error Enable bit (bit 3 of 
CTEST4). 


Bit 5 BF (Bus Fault) 

This bit is set when a PCI bus fault condition 
is detected. A PCI bus fault can only occur 
when the SYM53C876 SCSI function is bus 
master, and is defined as a cycle that ends with 
a Bad Address or Target Abort Condition. 
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Bit 4 ABRT (Aborted) 

This bit is set when an abort condition occurs. 
An abort condition occurs when a software 
abort command is issued by setting bit 7 of the 
ISTAT register. 

Bit 3 SSI (Single Step Interrupt) 

If the Single-Step Mode bit in the DCNTL 
register is set, this bit is set and an interrupt 
generated after successful execution of each 
SCRIPTS instruction. 

Bit 2 SIR (SCRIPTS Interrupt 
Instruction Received) 

This status bit is set whenever an Interrupt 
instruction is evaluated as true. 

Bit 1 Reserved 

Bit 0 IID (Illegal Instruction Detected) 

This status bit is set any time an illegal or 
reserved instruction op code is detected, 
whether the SYM53C876 SCSI function is 
operating in single-step mode or automatically 
executing SCSI SCRIPTS. Any of the follow¬ 
ing conditions during instruction execution 
also sets this bit: 

1. The SYM53C876 SCSI function is executing 
a Wait Disconnect instruction and the SCSI 
REQ line is asserted without a disconnect 
occurring. 

2. A Block Move instruction is executed with 
OOOOOOh loaded into the DBC register, 
indicating there are zero bytes to move. 

3. During a Transfer Control instruction, the 
Compare Data (bit 18) and Compare Phase 
(bit 17) bits are set in the DBC register while 
the SYM53C876 SCSI function is in target 
mode. 

4. During a Transfer Control instruction, the 
Carry Test bit (bit 21) is set and either the 
Compare Data (bit 18) or Compare Phase (bit 
17) bit is set. 

5. ATransfer Control instruction is executed with 


the reserved bit 22 set. 

6. ATransfer Control instruction is executed with 
the Wait for Valid phase bit (bit 16) set while 
the chip is in target mode. 

7. A Load/Store instruction is issued with the 
memory address mapped to the operating 
registers of the chip, not including ROM or 
RAM. 

8. A Load/Store instruction is issued when the 
register address is not aligned with the memory 
address 

9. A Load/Store instruction is issued with bit 5 in 
the DCMD register clear or bits 3 or 2 set. 

10. A Load/Store instruction when the count value 
in the DBC register is not set at 1 to 4. 

11. A Lx)ad/Store instruction attempts to cross a 
dword boundary. 

12. A Memory Move instruction is executed with 
one of the reserved bits in the DCMD register 
set. 

13. A Memory Move instruction is executed with 
the source and destination addresses not 
aligned. 


SYM53C876 Data Manual 


4-29 



Registers 

SCSI Registers 


PREUMINARY 


Register ODh 

SCSI Status Zero (SSTATO) 
Read Only 


ILF 

ORF 

OLF 

AIP 

LOA 

WOA 

RST/ 

SDPO/ 

7 

6 

5 

4 

3 

2 

1 

0 

Default »> 

0 0 

0 

0 

0 

0 

0 

0 


Bit 7 ILF (SIDL Least Significant Byte 
Full) 

This bit is set when the least significant byte in 
the SCSI Input Data Latch register (SIDL) 
contains data. Data is transferred from the 
SCSI bus to the SCSI Input Data Latch regis¬ 
ter before being sent to the DMA FIFO and 
then to the host bus. The SIDL register con¬ 
tains SCSI data received asynchronously. Syn¬ 
chronous data received does not flow through 
this register. 

Bit 6 ORF (SODR Least Significant Byte 
Full) 

This bit is set when the least significant byte in 
the SCSI Output Data Register (SODR, a hid¬ 
den buffer register which is not accessible) 
contains data. The SODR is used by the SCSI 
logic as a second storage register when sending 
data synchronously. It is not readable or writ¬ 
able by the user. It is possible to use this bit to 
determine how many bytes reside in the chip 
when an error occurs. 

Bit 5 OLF (SODL Least Significant Byte 
Full) 

This bit is set when the least significant byte in 
the SCSI Output Data Latch (SODL) contains 
data. The SODL register is the interface 
between the DMA logic and the SCSI bus. In 
synchronous mode, data is transferred from 
the host bus to the SODL register, and then to 
the SCSI Output Data Register (SODR, a hid¬ 
den buffer register which is not accessible) 
before being sent to the SCSI bus. In asyn¬ 
chronous mode, data is transferred from the 
host bus to the SODL register, and then to the 


SCSI bus. The SODR buffer register is not 
used for asynchronous transfers. It is possible 
to use this bit to determine how many bytes 
reside in the chip when an error occurs. 

Bit 4 AIP (Arbitration in Progress) 

Arbitration in Progress (AIP =1) indicates that 
the SYM53C876 SCSI function has detected a 
Bus Free condition, asserted BSY, and asserted 
its SCSI ID onto the SCSI bus. 

Bit 3 LOA (Lost Arbitration) 

When set, LOA indicates that the 
SYM53C876 SCSI function has detected a 
bus free condition, arbitrated for the SCSI bus, 
and lost arbitration due to another SCSI device 
asserting the SEL/ signal. 

Bit 2 WOA (Won Arbitration) 

When set, WOA indicates that the 
SYM53C876 SCSI function has detected a 
Bus Free condition, arbitrated for the SCSI 
bus and won arbitration. The arbitration mode 
selected in the SCNTLO register must be full 
arbitration and selection to set this bit. 

Bit 1 RST/ (SCSI RST/ Signal) 

This bit reports the current status of the SCSI 
RST/ signal, and the RST signal (bit 3) in the 
SCNTLl register. This bit is not latched and 
may change as it is read. 

Bit 0 SDPO/ (SCSI SDPO/ Parity Signal) 

This bit represents the active high current sta¬ 
tus of the SCSI SDPO/ parity signal. This signal 
is not latched and may change as it is read. 
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Register OEh 

SCSI Status One (SSTATl) 
Read Only 


FF3 

7 

FF2 

6 

FF1 

5 

FFO 

4 

SDPOL 

3 

MSG 

2 

C/D 

1 

I/O 

0 

Default »> 

0 0 

0 

0 

X 

X 

X 

X 

Bits 7-4 FF3-FF0 (FIFO Flags) 



These four bits, along with SSTAT2 bit 4, 
define the number of bytes or words that cur¬ 
rently reside in the 53C885’s SCSI synchro¬ 
nous data FIFO. These bits are not latched and 
they will change as data moves through the 
FIFO. Because the FIFO can only hold either 
sixteen bytes or sixteen words, values over six¬ 
teen can not occur. 


FF4 

(SSTAT2 
bit 4) 

FF3 

FF2 

FF1 

FFO 

Bytes or 
Words in 
the SCSI 
FIFO 

0 

0 

0 

0 

0 

0 

0 

0 

0 

0 

1 

1 

0 

0 

0 

1 

0 

2 

0 

0 

0 

1 

1 

3 

0 

0 

1 

0 

0 

4 

0 

0 

1 

0 

1 

5 

0 

0 

1 

1 

0 

6 

0 

0 

1 

1 

1 

7 

0 

1 

0 

0 

0 

8 

0 

1 

0 

0 

1 

9 

0 

1 

0 

1 

0 

10 

0 

1 

0 

1 

1 

11 

0 

1 

1 

0 

0 

12 

0 

1 

1 

0 

1 

13 

0 

1 

1 

1 

0 

14 

0 

1 

1 

1 

1 

15 

1 

0 

0 

0 

0 

16 


Bit 3 SDPOL (Latched SCSI Parity) 

This bit reflects the SCSI parity signal 
(SDPO/)j corresponding to the data latched in 
the SCSI Input Data Latch register (SIDL). It 
changes when a new byte is latched into the 
least significant byte of the SIDL register. This 
bit is active high, in other words, it is set when 
the parity signal is active. 

Bit 2 MSG (SCSI MSG/ Signal) 

Bit 1 C/D (SCSI C_D/ Signal) 

Bit 0 I/O (SCSI I_0/ Signal) 

These SCSI phase status bits are latched on the 
asserting edge of SREQ/ when operating in either 
initiator or target mode. These bits are set when 
the corresponding signal is active. They are useful 
when operating in low level mode. 
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Register OFh 

SCSI Status Two (SSTAT2) 
Read Only 


ILFl 

0RF1 

0LF1 

FF4 

SPL1 

RES 

LDSC 

SDP1 

7 

6 

5 

4 

3 

2 

1 

0 

Default »> 

0 0 

0 

0 

X 

X 

1 

X 


Bit 7 ILFl (SIDL Most Significant Byte 
Full) 

This bit is set when the most significant byte in 
the SCSI Input Data Latch register (SIDL) 
contains data. Data is transferred from the 
SCSI bus to the SCSI Input Data Latch regis¬ 
ter before being sent to the DMA FIFO and 
then to the host bus. The SIDL register con¬ 
tains SCSI data received asynchronously. Syn¬ 
chronous data received does not flow through 
this register. 

Bit 6 ORFl (SODR Most Significant Byte 
Full) 

This bit is set when the most significant byte in 
the SCSI Output Data Register (SODR, a hid¬ 
den buffer register which is not accessible) 
contains data. The SODR register is used by 
the SCSI logic as a second storage register 
when sending data synchronously. It is not 
accessible to the user. This bit is used to deter¬ 
mine how many bjnies reside in the chip when 
an error occurs. 

Bit 5 OLFl (SODL Most Significant Byte 
Full) 

This bit is set when the most significant byte in 
the SCSI Output Data Latch (SODL) contains 
data. The SODL register is the interface 
between the DMA logic and the SCSI bus. In 
synchronous mode, data is transferred from 
the host bus to the SODL register, and then to 
the SCSI Output Data Register (SODR, a hid¬ 
den buffer register which is not accessible) 
before being sent to the SCSI bus. In asyn¬ 
chronous mode, data is transferred from the 
host bus to the SODL register, and then to the 


SCSI bus. The SODR buffer register is not 
used for asynchronous transfers. It is possible 
to use this bit to determine how many bytes 
reside in the chip when an error occurs. 

Bit 4 FF4 (FIFO Flags bit 4) 

This is the most significant bit in the SCSI 
FIFO Flags field, with the rest of the bits in 
SSTATl. For a complete description of this 
field, see the definition for SSTATl bits 7-4. 

Bit 3 SPLl (Latched SCSI parity for SD15- 

8 ) 

This active high bit reflects the SCSI odd par¬ 
ity signal corresponding to the data latched 
into the most significant byte in the SIDL 
register. 

Bit 2 Reserved 

Bit 1 LDSC (Last Disconnect) 

This bit is used in conjtmction with the Con¬ 
nected (CON) bit in SCNTLl. It allows the 
user to detect the case in which a target device 
disconnects, and then some SCSI device 
selects or reselects the SYM53C876 SCSI 
function. If the Connected bit is asserted and 
the LDSC bit is asserted, a disconnect is indi¬ 
cated. This bit is set when the Connected bit in 
SCNTLl is off. This bit is cleared when a 
Block Move instruction is executed while the 
Connected bit in SCNTLl is on. 

Bit 0 SDPl (SCSI SDPl Signal) 

This bit represents the active-high current state 
of the SCSI SDPl parity signal. It is unlatched 
and may change as it is read. 
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Registers 10h-13h 

Data Structure Address (DSA) 

ReadlWrite 

This 32-bit register contains the base address used 
for all table indirect calculations.The DSA register 
is usually loaded prior to starting an I/O, but it is 
possible for a SCRIPTS Memory Move to load the 
DSA during the I/O. 

During any Memory-to-Memory Move operation, 
the contents of this register are preserved. The 
power-up value of this register is indeterminate. 


Register 14h 

Interrupt Status (ISTAT) 
ReadlWrite 


ABRT 

SRST 

SIGP 

SEM 

CON 

INTF 

SIP 

DIP 

7 

6 

5 

4 

3 

2 

1 

0 

Default »> 

0 0 

0 

0 

0 

0 

0 

0 


This is the only register that is accessible by the 
host CPU while a SYM53C876 SCSI function is 
executing SCRIPTS (without interfering in the 
operation of the function). It is used to poll for 
interrupts if hardware interrupts are disabled. 
Read this register after servicing an interrupt to 
check for stacked interrupts. For more information 
on interrupt handling refer to Chapter 2, “Func¬ 
tional Description.” 

Bit 7 ABRT (Abort Operation) 

Setting this bit aborts the current operation 
under execution by the SYM53C876 SCSI 
function. If this bit is set and an interrupt is 
received, reset this bit before reading the 
DSTAT register to prevent further aborted 
interrupts from being generated. The sequence 
to abort any operation is: 

1. Set this bit. 

2. Wait for an interrupt. 

3. Read the ISTAT register. 

4. If the SCSI Interrupt Pending bit is set, then 
read the SISTO or SISTl register to determine 
the cause of the SCSI Interrupt and go back to 
Step 2. 

5. If the SCSI Interrupt Pending bit is clear, and 
the DMA Interrupt Pending bit is set, then 
write OOh value to this register. 

6. Read the DSTAT register to verify the aborted 
interrupt and to see if any other interrupting 
conditions have occurred. 

Bit 6 SRST (Software Reset) 

Setting this bit resets the SYM53C876 SCSI 
function. All operating registers are cleared to 
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their respective default values and all SCSI sig¬ 
nals are deasserted. Setting this bit does not 
assert the SCSI RST/ signal. This reset does 
not clear the ID Mode bit or any of the PCI 
configuration registers. This bit is not self¬ 
clearing; it must be cleared to clear the reset 
condition (a hardware reset also clears this bit). 

Bit 5 SIGP (Signal Process) 

SIGP is a R/W bit that is writable at any time, 
and polled and reset via CTEST2.The SIGP 
bit is used in various ways to pass a flag to or 
from a running SCRIPTS instruction. 

The only SCRIPTS instruction directly 
affected by the SIGP bit is Wait For Selection/ 
Reselection. Setting this bit causes that 
instruction to jump to the alternate address 
immediately. The instructions at the alternate 
jump address should check the status of SIGP 
to determine the cause of the jump. The SIGP 
bit is usable at any time and is not restricted to 
the wait for selection/ reselection condition. 

Bit 4 SEM (Semaphore) 

The SCRIPTS processor may set this bit using 
a SCRIPTS register write instruction. An 
external processor may also set it while the 
SYM53C876 SCSI function is executing a 
SCRIPTS operation.This bit enables the SCSI 
function to notify an external processor of a 
predefined condition while SCRIPTS are run¬ 
ning. The external processor may also notify 
the SYM53C876 SCSI function of a pre¬ 
defined condition and the SCRIPTS processor 
may take action while SCRIPTS are executing. 

Bit 3 CON (Connected) 

This bit is automatically set any time the 
SYM53C876 SCSI function is connected to 
the SCSI bus as an initiator or as a target. It is 
set after successfully completing selection or 
when the SYM53C876 SCSI function 
responds to a bus-initiated selection or reselec¬ 
tion. It is also set after the SCSI function wins 
arbitration when operating in low level mode. 
When this bit is clear, the SYM53C876 SCSI 


fimction is not connected to the SCSI bus. 

Bit 2 INTF (Interrupt on the Fly) 

This bit is asserted by an INTFLY instruction 
during SCRIPTS execution. SCRIPTS pro¬ 
grams do not halt when the interrupt occurs. 
This bit can be used to notify a service routine, 
running on the main processor while the 
SCRIPTS processor is still executing a 
SCRIPTS program. If this bit is set, when the 
ISTAT register is read it is not automatically 
cleared. To clear this bit, write it to a one. The 
reset operation is self-clearing. 

Note: If the INTF bit is set but SIP or DIP is not 
set, do not attempt to read the other chip 
status registers. An interrupt-on-the-fly 
interrupt must be cleared before servicing 
any other interrupts indicated by SIP or 
DIP. 

Note: This bit must be written to one in order to 
clear it after it has been set. 

Bit 1 SIP (SCSI Interrupt Pending) 

This status bit is set when an interrupt condi¬ 
tion is detected in the SCSI portion of the 
SYM53C876 SCSI function. The following 
conditions cause a SCSI interrupt to occur: 

■ A phase mismatch (initiator mode) or 
SATN/ becomes active (target mode) 

■ An arbitration sequence completes 

■ A selection or reselection time-out occurs 

■ The SYM53C876 SCSI function is 
selected 

■ The SYM53C876 SCSI function is 
reselected 

■ A SCSI gross error occurs 

■ An unexpected disconnect occurs 

■ A SCSI reset occurs 

■ A parity error is detected 

■ The handshake-to-handshake timer is 
expired 
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■ The general purpose timer is expired. 

To determine exactly which condition(s) 
caused the interrupt, read the SISTO and 
SISTl registers. 

Bit 0 DIP (DlViA Interrupt Pending) 

This status bit is set when an interrupt condi¬ 
tion is detected in the DMA portion of the 
SYM53C876 SCSI function. The following 
conditions cause a DMA interrupt to occur: 

■ A PCI parity error is detected 

■ A bus fault is detected 

■ An abort condition is detected 

■ A SCRIPTS instruction is executed in 
single-step mode 

■ A SCRIPTS interrupt instruction is 
executed 


Register 18h 

Chip Test Zero (CTESTO) 
ReadlWrite 


m 

RES 

RES 


RES 

AP2 

API 

APO 

7 1 

6 



3 

2 

1 

0 

Default »> 

X X 

X 

X 

X 

0 

0 

0 


Bits 7-3 Reserved 

Bits 2-0 AP2-0 (Arbitration Priority 2-0) 

These bits are the priority used for gaining 
access to the PCI bus through the internal 
arbiter in the SYM53C876 SCSI function. 
Valid arbitration priority values are 0 (lowest 
priority) through 7 (highest priority). 


■ An illegal instruction is detected. 

To determine exactly which condition (s) 
caused the interrupt, read the DSTAT register. 
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Register 19h 

Chip Test One (CTESTl) 
Read Only 


Register lAh 

Chip Test Two (CTEST2) 

Read Only 


FMT3 

FMT2 

FMT1 

FMTO 

FFL3 

FFL2 

FFL1 

FFLO 

7 

6 

5 

4 

3 

2 

1 

0 

Default »> 

1 1 

1 

1 

0 

0 

0 

0 



Bits 7-4 FMT3-0 (Byte Empty in DMA FIFO) 

These bits identify the bottom bytes in the 
DMA FIFO that are empty. Each bit corre¬ 
sponds to a byte lane in the DMA FIFO. For 
example, if byte lane three is empty, then 
FMT3 is set. Since the FMT flags indicate the 
status of bytes at the bottom of the FIFO, if all 
FMT bits are set, the DMA FIFO is empty. 

Bits 3-0 FFL3-0 (Byte Full in DMA FIFO) 

These status bits identify the top bytes in the 
DMA FIFO that are full. Each bit corresponds 
to a byte lane in the DMA FIFO. For example, 
if byte lane three is full then FFL3 is set. Since 
the FFL flags indicate the status of bytes at the 
top of the FIFO, if all FFL bits are set, the 
DMA FIFO is full. 


Bit 7 DDIR (Data Transfer Direction) 

This status bit indicates which direction data is 
being transferred. When this bit is set, the data 
is transferred from the SCSI bus to the host 
bus. When this bit is clear, the data is trans¬ 
ferred from the host bus to the SCSI bus. 

Bit 6 SIGP (Signal Process) 

This bit is a copy of the SIGP bit in the ISTAT 
register (bit 5).The SIGP bit is used to signal a 
running SCRIPTS instruction. WTien this reg¬ 
ister is read, the SIGP bit in the ISTAT register 
is cleared. 

Bit 5 CIO (Configured as I/O) 

This bit is defined as the Configuration I/O 
Enable Status bit. This read-only bit indicates 
if the chip is currently enabled as I/O space. 

Note: Both bits 4 and 5 may be set if the chip is 
dual-mapped. 

Bit 4 CM (Configured as Memory) 

This bit is defined as the configuration mem¬ 
ory enable status bit. This read-only bit indi¬ 
cates if the chip is currently enabled as 
memory space. 

Note: Both bits 4 and 5 may be set if the chip is 
dual-mapped. 

Bit 3 SRTCH (SCRATCHA/B Operation) 

This bit controls the operation of the 
SCRATCHA and SCRATCHB registers. 
WTien it is set, SCRATCHB contains the RAM 
base address value from the PCI configuration 
RAM Base Address register. This is the base 
address for the 4 KB internal RAM. In addi- 
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tiorij the SCRATCHA register displays the 
memory-mapped based address of the chip 
operating registers. When this bit is cleared, the 
SCRATCHA and SCRATCHB registers 
return to normal operation. 

Note: Bit 3 is the only writable bit in this register. 
All other bits are read only. When 
modifying this register, all other bits must 
be written to zero. Do not execute a Read- 
Modify_Write to this register. 

Bit 2 TEOP (SCSI True End of Process) 

This bit indicates the status of the 
SYM53C876 SCSI function’s internal TEOP 
signal. The TEOP signal acknowledges the 
completion of a transfer through the SCSI por¬ 
tion of the SYM53C876 SCSI function. When 
this bit is set, TEOP is active. When this bit is 
clear, TEOP is inactive. 

Bit 1 DREQ (Data Request Status) 

This bit indicates the status of the 
SYM53C876 SCSI function’s internal Data 
Request signal (DREQ). When this bit is set, 
DREQ is active. When this bit is clear, DREQ 
is inactive. 

Bit 0 DACK (Data Acknowledge Status) 

This bit indicates the status of the 
SYM53C876 SCSI function’s internal Data 
Acknowledge signal (DACK/). When this bit is 
set, DACK/ is inactive. When this bit is clear, 
DACK/ is active. 


Register IBh 

Chip Test Three (CTEST3) 
ReadlWrite 


V3 

V2 

VI 

VO 

FLF 

CLF 

FM 

WRIE 

7 

6 

5 

4 

3 

2 

1 

0 

Default »> 

X X 

X 

X 

0 

0 

0 

0 


Bits 7-4 V3-V0 (Chip Revision Level) 

These bits identify the chip revision level for 
software purposes. It should have the same 
value as the lower nibble of the PCI Revision 
ID register. 

Bit 3 FLF (Flush DMA FIFO) 

When this bit is set, data residing in the DMA 
FIFO is transferred to memory, starting at the 
address in the DNAD register. The internal 
DMAWR signal, controlled by the CTEST5 
register, determines the direction of the trans¬ 
fer. This bit is not self clearing; reset it once the 
data is successfully transferred by the 
SYM53C876 SCSI function. 

Note: Polling of FIFO flags is allowed during 
flush operations. 

Bit 2 CLF (Clear D2VIA FIFO) 

When this bit is set, all data pointers for the 
DMA FIFO are cleared. Any data in the FIFO 
is lost. After the SYM53C876 SCSI function 
successfully clears the appropriate FIFO point¬ 
ers and registers, this bit automatically resets. 

Note: This bit does not clear the data visible at 
the bottom of the FIFO. 
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Bit 1 FM (Fetch Pin Mode) 

When set, this bit causes the FETCH/ pin to 
deassert during indirect and table indirect read 
operations. FETCH/ is only active during the 
op code portion of an instruction fetch. This 
allows the storage of SCRIPTS in a PROM 
while data tables are stored in RAM. 

If this bit is not set, FETCH/ is asserted for all 
bus cycles during instruction fetches. 

Bit 0 WRIE (Write and Invalidate Enable) 

This bit, when set, causes the issuing of Write 
and Invalidate commands on the PCI bus 
whenever legal. The Write and Invalidate 
Enable bit in the PCI Configuration Com¬ 
mand register must also be set in order for the 
chip to generate Write and Invalidate com¬ 
mands. 


Registers ICh-lFh 
Temporary (TEMP) 

Read/Write 

This 32-bit register stores the Return instruction 
address pointer from the Call instruction. The 
address pointer stored in this register is loaded into 
the DSP register when a Return instruction is exe¬ 
cuted. This address points to the next instruction 
to execute. Do not write to this register while the 
SYM53C876 SCSI function is executing 
SCRIPTS. 

During any Memory-to-Memory Move operation, 
the contents of this register are preserved. The 
power-up value of this register is indeterminate. 
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Register 20h 

DMA FIFO (DFIFO) 

ReadlWrite 


B07 

B06 

BOS 

B04 


B02 

CO 

o 


7 

6 

5 

4 

3 

2 

1 

Hi 

Default »> 

0 0 

0 

0 

0 

0 

0 

0 


Bits 7-0 BO7-BO0 (Byte offset counter) 

These bits, along with bits 1-0 in the CTEST5 
register, indicate the amount of data trans¬ 
ferred between the SCSI core and the DMA 
core. It is used to determine the number of 
bytes in the DMA FIFO when an interrupt 
occurs. These bits are unstable while data is 
being transferred between the two cores. Once 
the chip has stopped transferring data, these 
bits are stable. 

The DFIFO register counts the number of 
bytes transferred between the DMA core and 
the SCSI core. The DBC register counts the 
number of bytes transferred across the host 
bus. The difference between these two counters 
represents the number of bytes remaining in 
the DMA FIFO. 

The following steps determines how many 
bytes are left in the DMA FIFO when an error 
occurs, regardless of the transfer direction: 

1. If the DMA FIFO size is set to 88 bytes, 
subtract the seven least significant bits of the 
DBC register from the 7-bit value of the 
DFIFO register. If the DMA FIFO size is set 
to 536 bytes (using bit 5 of the CTEST 
register), subtract the 10 least significant bits of 
the DBC register from the 10-bit value of the 
DMA FIFO Byte Offset Counter, which is 
made up of the CTEST register (bits 1 and 0) 
and the DFIFO register (bits 7-0). 

2. If the DMA FIFO size is set to 88 bytes, AND 
the result with 7Fh for a b)rte count between 
zero and 64. If the DMA FIFO size is set 
to536 bytes, AND the result with 3FFh for a 
byte count between zero and 536. 


Register 21h 

Chip Test Four (CTEST4) 
ReadlWrite 


BDIS 

ZMOD 

ZSD 

SRTM 

mmjM 

FBL2 

FBL1 

FBLO 

7 

6 

5 

4 

a 

2 

1 

0 

Default »> 

0 0 

0 

0 

0 

0 

0 

0 


Bit 7 BDIS (Burst Disable) 

When set, this bit causes the SYM53C876 
SCSI function to perform back to back cycles 
for all transfers. When this bit is reset, back to 
back transfers for op code fetches and burst 
transfers for data moves are performed. 

Bit 6 ZMOD (High Impedance Mode) 

Setting this bit causes the SYM53C876 SCSI 
function to place all output and bidirectional 
pins into a high-impedance state. In order to 
read data out of the SYM53C876 SCSI func¬ 
tion, this bit must be cleared.This bit is 
intended for board-level testing only. Do not 
set this bit during normal system operation. To 
use this feature set the bit in both SCSI Func¬ 
tion A and SCSI Function B. 

Bit 5 ZSD (SCSI Data High Impedance) 

Setting this bit causes the SYM53C876 SCSI 
function to place the SCSI data bus SD(15-0) 
and the parity lines SDP(l-O) in a high-imped- 
ance state. In order to transfer data on the 
SCSI bus, clear this bit. 

Bit 4 SRTM (Shadow Register Test Mode) 

Setting this bit allows access to the shadow reg¬ 
isters used by memory-to-memory Move oper¬ 
ations. When this bit is set, register accesses to 
the TEMP and DS A registers are directed to 
the shadow copies STEMP (Shadow TEMP) 
and SDSA (Shadow DSA).The registers are 
shadowed to prevent them from being over¬ 
written during a Memory-to-Memory Move 
operation. The DSA and TEMP registers con¬ 
tain the base address used for table indirect 
calculations, and the address pointer for a call 
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or return instruction, respectively. This bit is 
intended for manufacturing diagnostics only 
and should not be set during normal opera¬ 
tions. 

Bit 3 2VIPEE (Master Parity Error Enable) 

Setting this bit enables parity checking during 
master data phases. A parity error during a bus 
master read is detected by the SYM53C876 
SCSI function. A parity error during a bus 
master write is detected by the target, and the 
SYM53C876 SCSI function is informed of the 
error by the PERR/ pin being asserted by the 
target. When this bit is reset, the SYM53C876 
SCSI function does not interrupt if a master 
parity error occurs. This bit is reset at power 
up. 

Bits 2-0 FBL2-FBL0 (FIFO Byte Control) 


FBL2 

FBLl 

FBLO 

DMA FIFO 
Byte lane 

Pins 

0 

X 

X 

Disabled 

n/a 

1 

0 

0 

0 

D(7-0) 

1 

0 

1 

1 

D(15-8) 

1 

1 

0 

2 

D(23-16) 

1 

1 

1 

3 

D(31-24) 


These bits steer the contents of the CTEST6 
register to the appropriate byte lane of the 32- 
bit DMA FIFO. If the FBL2 bit is set, then 
FBLl and FBLX) determine which of four byte 
lanes can be read or written. When cleared, the 
byte lane which is read or written is deter¬ 
mined by the current contents of the DNAD 
and DBC registers. Each of the four bytes that 
make up the 32-bit DMA FIFO is accessed by 
writing these bits to the proper value. For nor¬ 
mal operation, FBL2 must equal zero. 


Register 22h 

Chip Test Five (CTEST5) 
ReadlWrite 


ADCK 

BBCK 

DFS 

MASR 

DDIR 

BL2 

B09 

BOB 

7 

6 

5 

4 

3 

2 

1 

0 

Default »> 

0 0 

0 

0 

0 

0 

0 

0 


Bit 7 ADCK (Clock Address Incrementor) 

Setting this bit increments the address pointer 
contained in the DNAD register. The DNAD 
register is incremented based on the DNAD 
contents and the current DBC value. This bit 
automatically clears itself after incrementing 
the DNAD register. 

Bit 6 BBCK (Clock Byte Counter) 

Setting this bit decrements the byte count con¬ 
tained in the 24-bit DBC register. It is decre¬ 
mented based on the DBC contents and the 
current DNAD value. This bit automatically 
clears itself after decrementing the DBC regis¬ 
ter. 

Bit 5 DFS (DMA FIFO Size) 

This bit controls the size of the DMA FIFO. 
When clear, the DMA FIFO appears as only 
88 bytes deep. When set, the DMA FIFO size 
increases to 536 bytes. Using an 88-byte FIFO 
allows software written for other 
SYM53C8XX family chips to properly calcu¬ 
late the number of b3rtes residing in the chip 
after a target disconnect. The default value of 
this bit is zero. 

Bit 4 2V1ASR (Master Control for Set or 
Reset Pulses) 

This bit controls the operation of bit 3. When 
this bit is set, bit 3 asserts the corresponding 
signals. When this bit is reset, bit 3 deasserts 
the corresponding signals. Do not change this 
bit and bit 3 in the same write cycle. 
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Bit 3 DDIR (DMA Direction) 

Setting this bit either asserts or deasserts the 
internal DMA Write (DMAWR) direction sig¬ 
nal depending on the current status of the 
MASK bit in this register. Asserting the 
DMAWR signal indicates that data is trans¬ 
ferred from the SCSI bus to the host bus. 
Deasserting the DMAWR signal transfers data 
from the host bus to the SCSI bus. 

Bit BL2 (Burst Length bit 2) 

This bit works with bits 6 and 7 in the 
DMODE register to determine the burst 
length. For complete definitions of this field, 
refer to the descriptions of DMODE bits 6 and 
7. This bit is disabled if an 88-byte FIFO is 
selected by clearing the DMA FIFO Size bit. 

Bits 1-0 B09-B08 (DMA FIFO Byte Offset 
Counter, bits 9-8) 

These are the upper two bits of the DFBOC. 
Refer to the DFBOC register description for 
encodings of the BO9-0 bits. 


Register 23h 

Chip Test Six (CTEST6) 

Read/Write 


DF7 

DF6 

DF5 

DF4 

DF3 

DF2 

DF1 

DFO 

7 

6 

5 

4 

3 

2 

1 

0 

Default »> 

0 0 

0 

0 

0 

0 

0 

0 


Bits 7-0 DF7-DF0 (DMA FIFO) 

Writing to this register writes data to the 
appropriate byte lane of the DMA FIFO as 
determined by the FBL bits in the CTEST4 
register. Reading this register unloads data 
from the appropriate byte lane of the DMA 
FIFO as determined by the FBL bits in the 
CTEST4 register. Data written to the FIFO is 
loaded into the top of the FIFO. Data read out 
of the FIFO is taken from the bottom. To pre¬ 
vent DMA data from being corrupted, this reg¬ 
ister should not be accessed before starting or 
restarting SCRIPTS operation. Write this reg¬ 
ister only when testing the DMA FIFO using 
the CTEST4 register. Writing to this register 
while the test mode is not enabled produces 
imexpected results. 
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Registers 24h“26h 
DMA Byte Counter (DBG) 

ReadlWrite 

This 24-bit register determines the number of 
bytes transferred in a Block Move instruction. 
While sending data to the SCSI bus, the counter is 
decremented as data is moved into the DMA 
FIFO from memory. While receiving data from the 
SCSI bus, the counter is decremented as data is 
written to memory from the SYM53C876 SCSI 
function. The DBC counter is decremented each 
time data is transferred on the PCI bus. It is decre¬ 
mented by an amount equal to the number of 
bytes that are transferred. 

The maximum number of bytes that can be trans¬ 
ferred in any one Block Move command is 
16,777,215 bytes. The maximum value that can be 
loaded into the DBC register is FFFFFFh. If the 
instruction is a Block Move and a value of 
OOOOOOh is loaded into the DBC register, an illegal 
instruction interrupt occurs if the SYM53C876 
SCSI function is not in target mode. Command 
phase. 

The DBC register is also used to hold the least sig¬ 
nificant 24 bits of the first dword of a SCRIPTS 
fetch, and to hold the offset value during table 
indirect I/O SCRIPTS. For a complete description 
see Chapter 5, SCSI SCRIPTS Instruction 5et.The 
power-up value of this register is indeterminate. 


Register 27h 

DMA Command (DCMD) 

ReadlWrite 

This 8-bit register determines the instruction for 
the SYM53C876 SCSI function to execute. This 
register has a different format for each instruction 
For a complete description see Chapter 5, SCSI 
SCRIPTS Instruction Set. 
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Registers 28h-2Bh 

DMA Next Address (DNAD) 

ReadlWrite 

This 32-bit register contains the general purpose 
address pointer. At the start of some SCRIPTS 
operations, its value is copied from the DSPS reg¬ 
ister. Its value may not be valid except in certain 
abort conditions. The default value of this register 
is zero. 


Registers 2Ch-2Fh 

DMA SCRIPTS Pointer (DSP) 

ReadlWrite 

To execute SCSI SCRIPTS, the address of the 
first SCRIPTS instruction must be written to this 
register. In normal SCRIPTS operation, once the 
starting address of the SCRIPT is written to this 
register, SCRIPTS are automatically fetched and 
executed until an interrupt condition occurs. 

In single-step mode, there is a single step interrupt 
after each instruction is executed. The DSP regis¬ 
ter does not need to be written with the next 
address, but the Start DMA bit (bit 2, DCNTL 
register) must be set each time the step interrupt 
occurs to fetch and execute the next SCRIPTS 
command. When writing this register eight bits at a 
time, writing the upper eight bits begins execution 
of SCSI SCRIPTS. The default value of this regis¬ 
ter is zero. 
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Registers 30h-33h 

DMA SCRIPTS Pointer Save (DSPS) 

Read! Write 

This register contains the second longword of a 
SCRIPTS instruction. It is overwritten each time a 
SCRIPTS instruction is fetched. When a 
SCRIPTS interrupt instruction is executed, this 
register holds the interrupt vector. The power-up 
value of this register is indeterminate. 


Registers 34h 

Scratch Register A (SCRATCHA) 

Read! Write 

This is a general purpose, user-definable scratch 
pad register. Apart from CPU access, only Register 
Read/Write and Memory Moves into the 
SCRATCH register alter its contents. The power- 
up value of this register is indeterminate. 

A special mode of this register is enabled by setting 
the BAE bit in the CTEST5 register. If this bit is 
set, the SCRATCHA register returns the memory 
base address of the chip registers on the upper 24 
bits of the data bus when the SCRATCHA register 
is read. Writes tot he SCRATCHA register are 
unaffected. Resetting the BAE bit causes the 
SCRATCHA register to return to normal opera¬ 
tion. 
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Register 38h 

DMA Mode (DMODE) 

Read! Write 


BL1 

BLO 

SIOM 

DIOM 

ER 

ERMP 

BOF 

MAN 

7 

6 

5 

4 

3 

2 

1 

0 

Default »> 

0 0 

0 

0 

0 

0 

0 

0 


Bit 7-6 BLl-BLO (Burst Length) 

These bits control the maximum number of 
transfers performed per bus ownership, regard¬ 
less of whether the transfers are back-to-back, 
burst, or a combination of both. The 
SYM53C876 SCSI function asserts the Bus 
Request (REQ/) output when the DMA FIFO 
can accommodate a transfer of at least one 
burst size of data. Bus Request (REQ/) is also 
asserted during start-of-transfer and end-of- 
transfer cleanup and alignment, even if less 
than a full burst of transfers is performed. The 
SYM53C876 SCSI function inserts a “fairness 
delay” of four CLKs between burst-length 
transfers (as set in BLl-0) during normal oper¬ 
ation. The fairness delay is not inserted during 
PCI retry cycles. This gives the CPU and other 
bus master devices the opportunity to access 
the PCI bus between bursts. 


BL2 

(CTEST5 
bit 2) 

BL1 

BLO 

Burst Length 

0 

0 

0 

2- transfer burst 

0 

0 

1 

4- transfer burst 

0 

1 

0 

8-transfer burst 

0 

1 

1 

16-transfer burst 

1 

0 

0 

32-transfer burst* 

1 

0 

1 

64-transfer burst* 

1 

1 

0 

128-transfer burst* 

iliiliili 

1 

1 

' .kes'eryed:' 


*The 536 Byte FIFO must be enabled for these burst sizes 


Bit 5 SIOM (Source I/O-Memory Enable) 

This bit is defined as an HO Memory Enable 
bit for the source address of a Memory Move 
or Block Move Command. If this bit is set, 
then the source address is in FO space; and if 
reset, then the source address is in memory 
space. 

This function is useful for register-to-memory 
operations using the Memory Move instruc¬ 
tion when a SYM53C876 SCSI function is FO 
mapped. Bits 4 and 5 of the CTEST2 register 
is used to determine the configuration status of 
the SYM53C876 SCSI function SCSI func¬ 
tion. 

Bit 4 DIOM (Destination I/O-Memory 
Enable) 

This bit is defined as an FO Memory Enable 
bit for the destination address of a Memory 
Move or Block Move Command. If this bit is 
set, then the destination address is in FO 
space; and if reset, then the destination address 
is in memory space. 

This function is useful for memory-to-register 
operations using the Memory Move instruc¬ 
tion when a SYM53C876 SCSI function is FO 
mapped. Bits 4 and 5 of the CTEST2 register 
are used to determine the configuration status 
of the SYM53C876 SCSI function. 

Bit 3 ERL (Enable Read Line) 

This bit enables a PCI Read Line command. If 
this bit is set and the chip is about to execute a 
read cycle other than an op code fetch, then 
the command is 1110. 

Bit 2 ERMP (Enable Read Multiple) 

If this bit is set and cache mode is enabled, a 
Read Multiple command is used on all read 
cycles when it is legal. 

Bit 1 BOF (Burst Op Code Fetch Enable) 

Setting this bit causes the SYM53C876 SCSI 
function to fetch instructions in burst mode. 
Specifically, the chip bursts in the first two 
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longwords of all instructions using a single bus 
ownership. If the instruction is a memory-to- 
memory move type, the third longword is 
accessed in a subsequent bus ownership. If the 
instruction is an indirect type, the additional 
longword is accessed in a subsequent bus own¬ 
ership. If the instruction is a table indirect 
block move type, the chip accesses the remain¬ 
ing two longwords in a subsequent bus owner¬ 
ship, thereby fetching the four longwords 
required in two bursts of two longwords each. 
If prefetch is enabled, this bit has no effect. 
This bit also has no effect on fetches out of 
SCRIPT RAM. 

Bit 0 IVtAN (Manual Start Mode) 

Setting this bit prevents the SYM53C876 
SCSI function from automatically fetching and 
executing SCSI SCRIPTS when the DSP reg¬ 
ister is written. When this bit is set, the Start 
DMA bit in the DCNTL register must be set 
to begin SCRIPTS execution. Clearing this bit 
causes the SYM53C876 SCSI function to 
automatically begin fetching and executing 
SCSI SCRIPTS when the DSP register is writ¬ 
ten. This bit normally is not used for SCSI 
SCRIPTS operations. 


Register 39h 

DMA Interrupt Enable (DIEN) 
ReadlWrite 


RES 

MOPE 

BF 

ABRT 

SSI 

SIR 

RES 

IID 

7 

6 

5 

4 

3 

2 

1 

0 

Default >» 

X 0 

0 

0 

0 

0 

X 

0 


This register contains the interrupt mask bits cor¬ 
responding to the interrupting conditions 
described in the DSTAT register. An interrupt is 
masked by clearing the appropriate mask bit. 
Masking an interrupt prevents INTA/ (for Func¬ 
tion A) or INTB/ (for Function B) from being 
asserted for the corresponding interrupt, but the 
status bit is still set in the DSTAT register. Mask¬ 
ing an interrupt does not prevent setting the 
ISTAT DIP. All DMA interrupts are considered 
fatal, therefore SCRIPTS stops running when this 
condition occurs, whether or not the interrupt is 
masked. Setting a mask bit enables the assertion of 
INTA/, or INTB/, for the corresponding interrupt. 
(A masked non-fatal interrupt does not prevent 
un-masked or fatal interrupts from getting 
through; interrupt stacking begins when either the 
ISTAT SIP or DIP bit is set.) 

The INTA/ and INTB/ outputs are latched. Once 
asserted, they remain asserted imtil the interrupt is 
cleared by reading the appropriate status register. 
Masking an interrupt after the INTA/, or INTB/, 
output is asserted does not cause deassertion of 
INTA/, or INTB/. 

For more information on interrupts, see Chapter 
2, Functional Description. 

Bit 7 Reserved 

Bit 6 2V1DPE (Master Data Parity Error) 

Bit 5 BF (Bus Fault) 

Bit 4 ABRT (Aborted) 


Bit 3 SSI (Single -step Interrupt) 

Bit 2 SIR (SCRIPTS Interrupt 

Instruction Received 
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Bit 1 Reserved 

Bit 0 IID (Illegal Instruction Detected) 


Register 3Ah 

Scratch Byte Register (SBR) 

Read! Write 

This is a general purpose register. Apart from CPU 
access, only Register Read/Write and Memory 
Moves into this register alter its contents. The 
default value of this register is zero. This register is 
called the DMA Watchdog Timer on previous 
SYM53C8XX family products. 
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Register 3Bh 

DMA Control (DCNTL) 

ReadlWrite 


CLSE 

PFF 

PFEN 

SSM 

INTM 

STD 

INTD 

COM 

7 

6 

5 

4 

3 

2 

1 

0 

Default »> 

0 0 

0 

0 

0 

0 

0 

0 


Bit 7 CLSE (Cache Line Size Enable) 

Setting this bit enables the SYM53C876 SCSI 
function to sense and react to cache line 
boundaries set up by the DMODE or PCI 
Cache Line Size register, whichever contains 
the smaller value. Clearing this bit disables the 
cache line size logic and the SYM53C876 
SCSI function monitors the cache line size via 
the DMODE register. 

Bit 6 PFF (Pre-fetch Flush) 

Setting this bit causes the pre-fetch unit to 
flush its contents. The bit resets after the flush 
is complete. 

Bit 5 PFEN (Pre-fetch Enable) 

Setting this bit enables the pre-fetch unit if the 
burst size is equal to or greater than four. For 
more information on SCRIPTS instruction 
prefetching, see Chapter 2. 

Bit 4 SSM (Single-step Mode) 

Setting this bit causes the SYM53C876 SCSI 
function to stop after executing each SCRIPTS 
instruction, and generate a single step inter¬ 
rupt. When this bit is clear the SYM53C876 
SCSI function does not stop after each instruc¬ 
tion. It continues fetching and executing 
instructions xintil an interrupt condition 
occurs. For normal SCSI SCRIPTS operation, 
keep this bit clear. To restart the SYM53C876 
SCSI function after it generates a SCRIPTS 
Step interrupt, read the ISTAT and DSTAT 
registers to recognize and clear the interrupt. 
Then set the START DMA bit in this register. 

Bit 3 INTM (INTA Mode) 


When set, this bit enables a totem pole driver 
for the INTA/, or INTB/ pin. When reset, this 
bit enables an open drain driver for the INTA/, 
or INTB/, pin with an internal weak pull-up. 
This bit is reset at power up. The bit should 
remain clear to retain full PCI compliance. 

Bit 2 STD (Start DMA Operation) 

The SYM53C876 SCSI function fetches a 
SCSI SCRIPTS instruction from the address 
contained in the DSP register when this bit is 
set. This bit is required if the SYM53C876 
SCSI function is in one of the following 
modes: 

1. Manual start mode - Bit 0 in the DMODE 
register is set 

2. Single-step mode - Bit 4 in the DCNTL 
register is set 

When the SYM53C876 SCSI function is exe¬ 
cuting SCRIPTS in manual start mode, the 
Start DMA bit must be set to start instruction 
fetches, but need not be set again imtil an 
interrupt occurs. When the SYM53C876 SCSI 
fimction is in single-step mode, set the Start 
DMA bit to restart execution of SCRIPTS 
after a single-step interrupt. 

Bit 1 IRQD (INTA, INTB Disable) 

Setting this bit disables the INTA (for SCSI 
Fimction A), or INTB (for SCSI Function B) 
pin. Clearing the bit enables normal operation. 
As with any other register other than ISTAT, 
this register can not be accessed except by a 
SCRIPTS instruction during SCRIPTS execu¬ 
tion. For more information on the use of this 
bit in interrupt handling, see Chapter 2. 

Bit 0 COM (53C700 Compatibility) 

When the COM bit is clear, the SYM53C876 
SCSI function behaves in a manner compatible 
with the SYM53C700; selection/reselection 
IDs are stored in both the SSID and SFBR 
registers. This bit is not effected by a software 
reset. 
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If the COM bit is cleared, do not access this 
register via SCRIPTS operation as non-deter- 
minate operations may occur. (This includes 
SCRIPTS Read/Write operations and condi¬ 
tional transfer control instructions that initial¬ 
ize the SFBR register.) 

When the COM bit is set, the ID is stored only 
in the SSID register, protecting the SFBR from 
being overwritten if a selection/reselection 
occurs during a DMA register-to-register oper¬ 
ation. 


Register 3Ch-3Fh 

Adder Sum Output (ADDER) 

Read Only 

This register contains the ouqjut of the internal 
adder, and is used primarily for test purposes. The 
power-up value for this register is indeterminate. 
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Register 40h 

SCSI Interrupt Enable Zero (SIENO) 
Read! Write 


M/A 

CMP 

SEL 

RSL 

SGE 

UDC 

RST 

PAR 

7 

6 

5 

4 

3 

2 

1 

0 

Default »> 

0 0 

0 

0 

0 

0 

0 

0 


This register contains the interrupt mask bits cor¬ 
responding to the interrupting conditions 
described in the SISTO register. An interrupt is 
masked by clearing the appropriate mask bit. For 
more information on interrupts, see Chapter 2, 
Functional Description. 

Bit 7 MIA (SCSI Phase Mismatch - 
Initiator Mode; SCSI ATN 
Condition - Target Mode) 

In initiator mode, this bit is set when the SCSI 
phase asserted by the target and sampled dur¬ 
ing SREQ/ does not match the expected phase 
in the SOCL register. This expected phase is 
automatically written by SCSI SCRIPTS. In 
target mode, this bit is set when the initiator 
asserts SATN/. See the Disable Halt on Parity 
Error or SATN/ Condition bit in the SCNTLl 
register for more information on when this sta¬ 
tus is actually raised. 

Bit 6 CMP (Function Complete) 

Indicates full arbitration and selection 
sequence is completed. 

Bits SEL (Selected) 

Indicates the SYM53C876 SCSI function is 
selected by a SCSI target device. Set the 
Enable Response to Selection bit in the SCID 
register for this to occur. 

Bit 4 RSL (Reselected) 

Indicates the SYM53C876 SCSI function is 
reselected by a SCSI initiator device. Set the 
Enable Response to Reselection bit in the 
SCID register for this to occur. 


Bit 3 SGE (SCSI Gross Error) 

The following conditions are considered SCSI 
Gross Errors: 

1. Data underflow - reading the SCSI FIFO when 
no data is present. 

2. Data overflow - writing to the SCSI FIFO 
while it is full. 

3. Offset underflow - receiving a SACK/ pulse in 
target mode before the corresponding SREQ/ 
is sent. 

4. Offset overflow - receiving an SREQ/ pulse in 
initiator mode, and exceeding the maximum 
offset (defined by the MO3-0 bits in the 
SXFER register). 

5. A phase change in initiator mode, with an 
outstanding SREQ/SACK offset. 

6. Residual data in SCSI FIFO - starting a 
transfer other than synchronous data receive 
with data left in the SCSI synchronous receive 
FIFO. 

Bit 2 UDC (Unexpected Disconnect) 

This condition only occurs in initiator mode. It 
happens when the target to which the 
SYM53C876 SCSI function is connected dis¬ 
connects from the SCSI bus unexpectedly. See 
the SCSI Disconnect Unexpected bit in die 
SCNTL2 register for more information on 
expected versus tmexpected disconnects. Any 
disconnect in low level mode causes this condi¬ 
tion. 

Bit 1 RST (SCSI Reset Condition) 

Indicates assertion of the SRST/ signal by the 
SYM53C876 SCSI function or any other SCSI 
device. This condition is edge-triggered, so 
multiple interrupts cannot occur because of a 
single SRST/ pulse. 

Bit 0 PAR (SCSI Parity Error) 

Indicates detection by the SYM53C876 SCSI 
function of a parity error while receiving or 
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sending SCSI data. See the Disable Halt on 
Parity Error or SATN/ Condition bits in the 
SCNTLl register for more information on 
when this condition is actually raised. 


Register 41h 

SCSI Interrupt Enable One (SIENl) 
ReadlWrite 



This register contains the interrupt mask bits cor¬ 
responding to the interrupting conditions 
described in the SISTl register. An interrupt is 
masked by clearing the appropriate mask bit. For 
more information on interrupts, refer to Chapter 
2, “Functional Description.” 

Bits 7-3 Reserved 

Bit 2 STO (Selection or Reselection Time¬ 
out) 

The SCSI device which the SYM53C876 
SCSI function is attempting to select or rese¬ 
lect does not respond within the programmed 
time-out period. See the description of the 
STIMEO register bits 3-0 for more information 
on the time-out timer. 

Bit 1 GEN (General Purpose Timer 
Expired) 

The general purpose timer is expired. The time 
measured is the time between enabling and dis¬ 
abling of the timer. See the description of the 
STIMEl register, bits 3-0, for more informa¬ 
tion on the general purpose timer. 

Bit 0 HTH ( Handshake-to-Handshake 
Timer Expired) 

The handshake-to-handshake timer is expired. 
The time measured is the SCSI Request-to- 
Request (target) or Acknowledge-to-Acknowl- 
edge (initiator) period. See the description of 
the STIMEO register, bits 7-4, for more infor¬ 
mation on the handshake-to-handshake timer. 
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Register 42h 

SCSI Interrupt Status Zero (SISTO) 
Read Only 


M/A 

CMP 

SEL 

RSL 

SGE 

UDC 

RST 

PAR 

7 

6 

5 

4 

3 

2 

1 

0 

Default »> 

0 0 

0 

0 

0 

0 

0 

0 


Reading the SISTO register returns the status of 
the various interrupt conditions, whether they are 
enabled in the SIENO register or not. Each bit set 
indicates occurrence of the corresponding condi¬ 
tion. Reading the SISTO clears the interrupt sta¬ 
tus. 

Reading this register clears any bits that are set at 
the time the register is read, but does not necessar¬ 
ily clear the register because additional interrupts 
may be pending (the SYM53C876 SCSI functions 
stack interrupts). SCSI interrupt conditions are 
individually masked through the SIENO register. 

When performing consecutive 8-bit reads of the 
DSTAT, SISTO, and SISTl registers (in any 
order), insert a delay equivalent to 12 CLK peri¬ 
ods between the reads to ensure the interrupts 
clear properly. Also, if reading the registers when 
both the ISTAT SIP and DIP bits may not be set, 
read the SISTO and SISTl registers before the 
DSTAT register to avoid missing a SCSI interrupt. 
For more information on interrupts, refer to Chap¬ 
ter 2, “Functional Description.” 

Bit 7 M/A (Initiator Mode: Phase Mis¬ 
match; Target Mode: SATN/Active) 

In initiator mode, this bit is set if the SCSI 
phase asserted by the target does not match the 
instruction. The phase is sampled when SREQ/ 
is asserted by the target. In target mode, this 
bit is set when the SATN/ signal is asserted by 
the initiator. 

Bit 6 CMP (Function Complete) 

This bit is set when an arbitration only or full 
arbitration sequence is completed. 


Bit 5 SEL (Selected) 

This bit is set when the SYM53C876 SCSI 
function is selected by another SCSI device. 
The Enable Response to Selection bit must be 
set in the SCID register (and the RESPID reg¬ 
ister must hold the chip’s ID) for the 
SYM53C876 SCSI function to respond to 
selection attempts. 

Bit 4 RSL (Reselected) 

This bit is set when the SYM53C876 SCSI 
function is reselected by another SCSI device. 
The Enable Response to Reselection bit must 
be set in the SCID register (and the RESPID 
register must hold the chip’s ID) for the 
SYM53C876 SCSI function to respond to 
reselection attempts. 

Bit 3 SGE (SCSI Gross Error) 

This bit is set when the SYM53C876 SCSI 
function encounters a SCSI Gross Error Con¬ 
dition. The following conditions can result in a 
SCSI Gross Error Condition: 

1. Data Underflow - reading the SCSI FIFO 
register when no data is present. 

2. Data Overflow - writing too many bytes to the 
SCSI FIFO, or the synchronous offset causes 
overwriting the SCSI FIFO. 

3. Offset Underflow-the SYM53C876 SCSI 
function is operating in target mode and a 
SACK/ pulse is received when the outstanding 
offset is zero. 

4. Offset Overflow - the other SCSI device sends 
a SREQ/ or SACK/ pulse with data which 
exceeds the maximum synchronous offset 
defined by the SXFER register. 

5. A phase change occurs with an outstanding 
synchronous offset when the SYM53C876 
SCSI function is operating as an initiator. 

6. Residual data in the Synchronous data FIFO - 
a transfer other than synchronous data receive 
is started with data left in the synchronous data 
FIFO. 


4-52 


SYM53C876 Data Manual 




PRELIMINARY 


Registers 

SCSI Registers 


Bit 2 UDC (Unexpected Disconnect) 

This bit is set when the SYM53C876 SCSI 
function is operating in initiator mode and the 
target device unexpectedly disconnects from 
the SCSI bus. This bit is only valid when the 
SYM53C876 SCSI function operates in the 
initiator mode. When the SCSI function oper¬ 
ates in low level mode, any disconnect causes 
an interrupt, even a valid SCSI disconnect. 
This bit is also set if a selection time-out occurs 
(it may occur before, at the same time, or 
stacked after the STO interrupt, since this is 
not considered an expected disconnect). 

Bit 1 RST (SCSI RST/ Received) 

This bit is set when the SYM53C876 SCSI 
function detects an active SRST/ signal, 
whether the reset is generated external to the 
chip or caused by the Assert SRST/ bit in the 
SCNTLl register. This SCSI reset detection 
logic is edge-sensitive, so that multiple inter¬ 
rupts are not generated for a single assertion of 
the SRST/ signal. 

Bit 0 PAR (Parity Error) 

This bit is set when the SYM53C876 SCSI 
function detects a parity error while receiving 
SCSI data.The Enable Parity Checking bit (bit 
3 in the SCNTLO register) must be set for this 
bit to become active. The SYM53C876 SCSI 
function always generates parity when sending 
SCSI data. 


Register 43h 

SCSI Interrupt Status One (SISTl) 
Read Only 


RES ' 


RES , 

RES 

RES 

STO 

GEN 

HTH 

7 

6 

; 5 

4 


2 

1 

0 

Default »> 

X X 

X 

X 

0 

0 

0 

0 


Reading the SISTl register returns the status of 
the various interrupt conditions, whether they are 
enabled in the SIENl register or not. Each bit that 
is set indicates an occurrence of the corresponding 
condition. 

Reading the SISTl clears the interrupt condition. 
Bits 7-4 Reserved 

Bit 2 STO (Selection or Reselection Time¬ 
out) 

The SCSI device which the SYM53C876 
SCSI function is attempting to select or rese¬ 
lect does not respond within the programmed 
time-out period. See the description of the 
STIMEO register, bits 3-0, for more informa¬ 
tion on the time-out timer. 

Bit 1 GEN (General Purpose Timer 
Expired) 

This bit is set when the general purpose timer 
expires. The time measured is the time between 
enabling and disabling of the timer. See the 
description of the STIMEl register, bits 3-0, 
for more information on the general purpose 
timer. 
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Bit 0 HTH (Handshake-to-Handshake 
Timer Expired) 

This bit is set when the handshake-to-hand- 
shake timer expires. The time measured is the 
SCSI Request to Request (target) or Acknowl¬ 
edge to Acknowledge (initiator) period. See the 
description of the STTMEO register, bits 7-4, 
for more information on the handshake-to- 
handshake timer. 


Register 44h 

SCSI Longitudinal Parity (SLPAR) 
ReadlWrite 

This register performs a bytewise longitudinal par¬ 
ity check on all SCSI data received or sent through 
the SCSI core. If one of the bytes received or sent 
(usually the last) is the set of correct even parity 
bits, SLPAR should go to zero (assuming it started 
at zero). As an example, suppose that the following 
three data bytes and one check byte are received 
from the SCSI bus (all signals are shown active 
high): 


Data Bytes 

Running SLPAR 

■— 

00000000 

1.11001100 

11001100 (XORofword 1) 

2.01010101 

10011001 (XOR of word 1 and 2) 

3.00001111 

10010110 (XOR of word 1,2 and 3) 
Even Parity >>>10010110 

4.10010110 

00000000 


A one in any bit position of the final SLPAR value 
would indicate a transmission error. 

The SLPAR register is also used to generate the 
check bytes for SCSI send operations. If the 
SLPAR register contains all zeros prior to sending 
a block move, it contains die appropriate check 
byte at the end of the block move. This byte must 
then be sent across the SCSI bus. 

Note: Writing any value to this register resets it to 
zero. 

The longitudinal parity checks are meant to pro¬ 
vide an added measure of SCSI data integrity and 
are entirely optional. This register does not latch 
SCSI selection/reselection IDs imder any circum¬ 
stances. The default value of this register is zero. 

The longitudinal parity function normally operates 
as a byte function. During 16-bit transfers, the 
high and low bytes are XORed together and then 
XORed into the current longitudinal parity value. 
By setting the SLPMD bit in the SCNTL3 regis¬ 
ter, the longitudinal parity function is made to 
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operate as a word-wide function. During 16-bit 
transfers, the high byte of the SCSI bus is XORed 
with the high byte of the current longitudinal par¬ 
ity value, and the low byte of the SCSI bus is 
XORed with the low byte of the current longitudi¬ 
nal parity value. In this mode, the 16-bit longitudi¬ 
nal parity value is accessed a byte at a time through 
the SLPAR register. Which byte is accessed is con¬ 
trolled by the SLPHBEN bit in the SCNTL3 reg¬ 
ister. 


Register 45h 

SCSI Wide Residue (SWIDE) 

ReadlWrite 

After a wide SCSI data receive operation, this reg¬ 
ister contains a residual data byte if the last byte 
received was never sent across the DMA bus. It 
represents either the first data byte of a subsequent 
data transfer, or it is a residue byte which should 
be cleared when an Ignore Wide Residue message 
is received. It may also be an overrun data byte. 
The power-up value of this register is indetermi¬ 
nate. 
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Register 46h 

Memory Access Control (MACNTL) 
Read/Write 


TYP3 

TYP2 

TYP1 

TYPO 

■ 



■aa 

7 

6 

5 

4 


1 



Default »> 

0 1 

1 

1 

X 

X 

X 

X 


Bits 7-4 TYP3-0 (Chip Type) 

These bits identify the chip type for software 
purposes. This data manual applies to devices 
that have these bits set to 70h. 

Bit 3-0 Reserved 


Register 47h 

General Purpose Pin Control (GPCNTL) 
ReadlWrite 


1 1 

FE 


GPI04 

GPI03 

GPI02 

GPI01 

GPIOO 


6 

5 

4 

3 

2 

1 

0 

Default »> 

0 0 

X 

0 

1 

1 

1 

1 


This register is used to determine if the pins con¬ 
trolled by the General Purpose register (GPREG) 
are inputs or outputs. Bits 4-0 in GPCNTL corre¬ 
spond to bits 4-0 in the GPREG register. When the 
bits are enabled as inputs, an internal pull-up is 
also enabled. If either SCSI function GPCNTL 
Register has a GPIO pin set as an output, the pin is 
enabled as an output. If both the SCSI ftmction 
GPREG registers define a single GPIO pin as an 
output, the results are indeterminate. 

Bit 7 Master Enable 

The internal bus master signal is presented on 
GPIOl if this bit is set, regardless of the state 
of Bit 1 (GPI01_EN) . 

Bit 6 Fetch Enable 

The internal op code fetch signal is presented 
on GPIOO if this bit is set, regardless of the 
state of Bit 0 (GPIOO.EN). 

Bits 5 Reserved 

Bits 4,2 GPI04_EN-GPI02_EN (GPIO 
Enable) 

General purpose control, corresponding to bit 
4 in the GPREG register and the GPI04 pin. 
GPI04 powers-up as a general purpose out¬ 
put, and GPI03-2 power-up as general pur¬ 
pose inputs. 

Bits 1-0 GPIOl_EN-GPIO0_EN (GPIO 
Enable) 

These bits power-up set, causing the GPIOl 
and GPIOO pins to become inputs. Resetting 
these bits causes GPIO 1-0 to become outputs. 
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Register 48h 

SCSI Timer Zero (STIMEO) 
ReadlWrite 


HTH7 

HTH6 

HTH5 

HRH4 



SEL 


7 

6 

5 

4 

3 

2 

1 

0 

Default »> 

0 0 

0 

0 

0 

0 

0 

0 


Bits 7-4 HTH (Handshake-to-Handshake 
Timer Period) 

These bits select the handshake-to-handshake 
time-out period, the maximum time between 
SCSI handshakes (SREQ/ to SREQ/ in target 
mode, or SACK/ to SACK/ in initiator mode). 
When this timing is exceeded, an interrupt is 
generated and the HTH bit in the SISTl regis¬ 
ter is set. The following table contains time-out 
periods for the Handshake-to-Handshake 
Timer, the Selection/Reselection Timer (bits 3- 
0), and the General Purpose Timer (STIMEl 
bits 3-0). For a more detailed explanation of 
interrupts, refer to Chapter 2, Functional 
Description.” 


HTH 7-4, 
SEL 3-0, 

GEN 3-0 

Minimum Time-out 
(80 MHz Ciock)with 
scaie factor bit reset 

Minimum Time-out 
(80MHzCiock)with 
scale factor bit set 

0000 

Disabled 

Disabled 

0001 

100 ps 

1.6 ms 

0010 

200 ps 

3.2 ms 

0011 

400 ps 

6.4 ms 

0100 

800 ps 

12.8 ms 

0101 

.6 ms 

25.6 ms 

0110 

3.2 ms 

51.2 ms 

0111 

6.4 ms 

102.4 ms 

1000 

12.8 ms 

204.8 ms 

1001 

25.6 ms 

409.6 ms 

1010 

51.2 ms 

819.2 ms 

1011 

102.4 ms 

1.6 sec 

1100 

204.8 ms 

3.2 sec 

1101 

409.6 ms 

6.4 sec 

1110 

19.2 ms 

12.8 sec 

nil 

1.6+ sec 

25.6 sec 

These values are correct if the CCF bits in the SCNTL3 
register are set according to the valid combinations in the bit 
description. 


Bits 3-0 SEL (Selection Time-Out) 

These bits select the SCSI selection/reselection 
time-out period. When this timing (plus the 
200 ps selection abort time) is exceeded, the 
STO bit in the SISTl register is set. For a 
more detailed explanation of interrupts, refer 
to Chapter 2, “Functional Description.” 
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Register 49h 

SCSI Timer One (STIMEl) 

ReadlWrite 

HTHSFI GEN3 GEN2 GEN1 
4 3 2 1 

XOOOOOOO 



GENO 

0 


Register 4Ah 

Response ID Zero (RESPIDO) 
ReadlWrite 

ID iD“l iD~| iD~| iD~[ ID ID“”| io 

7 6 5 4 3 2 1 0 

Default »> 

xxxxxxxx 


Bit 7 Reserved 

Bit 6 HTHBA (Handshake-to-Handshake 

Timer Bus Activity Enable) 

Setting this bit causes this timer to begin test¬ 
ing for SCSI REQ/ACK activity as soon as 
SBSY/ is asserted, regardless of the agents par¬ 
ticipating in the transfer. 

Bit 5 GENSF (General Purpose Timer 
Scale Factor) 

Setting this bit causes this timer to shift by a 
factor of 16. Refer to the STIMEO register 
description for details. 

Bit 4 HTHSF (Handshake to Handshake 
Timer Scale Factor) 

Setting this bit causes this timer to shift by a 
factor of 16. Refer to the STIMEO register 
description for details 

Bits 3-0 GEN3-0 (General Purpose Timer 
Period) 

These bits select the period of the general pur¬ 
pose timer. The time measured is the time 
between enabling and disabling of the timer. 
When this timing is exceeded, the GEN bit in 
the SISTl register is set. Refer to the table 
under STIMEO, bits 3-0, for the available 
time-out periods. 

Note: To reset a timer before it expires and obtain 
repeatable delays, the time value must be 
written to zero first, and then written back 
to the desired value. This is also required 
when changing from one time value to 
another. 


RESPIDO and RESPIDl contain the selection or 
reselection IDs. In other words, these two 8-bit 
registers contain the ID that the chip responds to 
on the SCSI bus. Each bit represents one possible 
ID with the most significant bit of RESPIDl rep¬ 
resenting ID 15 and the least significant bit of 
RESPIDO representing ID O.The SCID register 
still contains the chip ID used during arbitration. 
The chip can respond to more than one ID 
because more than one bit can be set in the 
RESPIDl and RESPIDO registers. However, the 
chip can arbitrate with only one ID value in the 
SCID register. 
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Register 4Bh 

Response ID One (RESPIDl) 
Read! Write 


ID 

ID 

ID 

ID 

ID 

ID 

ID 

ID 

15 

14 

13 

12 

11 

10 

9 

8 

Default »> 

X X 

X 

X 

X 

X 

X 

X 


RESPIDO and RESPIDl contain the selection or 
reselection IDs. In other words, these two 8-bit 
registers contain the ID that the chip responds to 
on the SCSI bus. Each bit represents one possible 
ID with the most significant bit of RESPIDl rep¬ 
resenting ID 15 and the least significant bit of 
RESPIDO representing ID 0. The SCID register 
still contains the chip ID used during arbitration. 
The chip can respond to more than one ID 
because more than one bit can be set in the 
RESPIDl and RESPIDO registers. However, the 
chip can arbitrate with only one ID value in the 
SCID register. 


Register 4Ch 

SCSI Test Zero (STESTO) 
Read Only 


SSAID3 

SSAID2 

SSAID1 

SSAIDO 


«!■ 

soz 

SOM 

7 

6 

5 

4 

B 

m 

1 

0 

Default »> 

0 0 

0 

0 

0 

X 

1 

1 


Bits 7-4 SSAID3-0 (SCSI Selected As ID) 

These bits contain the encoded value of the 
SCSI ID that the SYM53C876 SCSI function 
is selected or reselected as during a SCSI selec¬ 
tion or reselection phase. These bits are read 
only and contain the encoded value of 0-15 
possible IDs that could be used to select the 
SYM53C876 SCSI function. During a SCSI 
selection or reselection phase when a valid ID 
is put on the bus, and the SYM53C876 SCSI 
function responds to that ID, the “selected as” 
ID is written into these bits. These bits are 
used with the RESPID registers to allow 
response to multiple IDs on the bus. 

Bit 3 SLT (Selection Response Logic Test) 

This bit is set when the SYM53C876 SCSI 
function is ready to be selected or reselected. 
This does not take into accoimt the bus settle 
delay of 400 ns. This bit is used for functional 
test and fault purposes. 

Bit 2 ART (Arbitration Priority Encoder 
Test) 

This bit is always set when the SYM53C876 
SCSI function exhibits the highest priority ID 
asserted on the SCSI bus during arbitration. It 
is primarily used for chip level testing, but it 
may be used during low level mode operation 
to determine if the SYM53C876 SCSI func¬ 
tion won arbitration. 
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Bit 1 SOZ (SCSI Synchronous Offset Zero) 

This bit indicates that the current synchronous 
SREQ/SACK offset is zero. This bit is not 
latched and may change at any time. It is used 
in low level synchronous SCSI operations. 
When this bit is set, the SYM53C876 SCSI 
functionj as an initiator, is waiting for the tar¬ 
get to request data transfers. If the 
SYM53C876 SCSI function is a target, then 
the initiator has sent the offset number of 
acknowledges. 

Bit 0 SOM (SCSI Synchronous Offset 
Maximum) 

This bit indicates that the current synchronous 
SREQ/SACK offset is the maximum specified 
by bits 3-0 in the SCSI Transfer register. This 
bit is not latched and may change at any time. 
It is used in low level synchronous SCSI opera¬ 
tions. When this bit is set, the SYM53C876 
SCSI fimction, as a target, is waiting for the 
initiator to acknowledge the data transfers. If 
the SYM53C876 SCSI function is an initiator, 
then the target has sent the offset number of 
requests. 


Register 4Dh 

SCSI Test One (STESTl) 

ReadlWrite 


SCLK 

ISO 


RES 

DBLEN 

DBLSEL 

"RESi 

RES 

7 

6 


4 

3 

2 

1 

0 

Default >» 

0 0 

X 

X 

0 

0 

X 

X 


Bit 7 SCLK 

When set, this bit disables the external SCLX 
(SCSI Clock) pin, and the chip uses the PCI 
clock as the internal SCSI clock. If a transfer 
rate of 10 Mb/s (or 20 MB/s on a wide SCSI 
bus) is desired on the SCSI bus, this bit must 
be reset and at least a 40 MHz external SCLK 
must be provided. 

Bit 6 ISO_MODE (SCSI Isolation Mode) 

This bit allows the SYM53C876 SCSI func¬ 
tion to put the SCSI bi-directional and input 
pins into a low power mode when the SCSI bus 
is not in use. When ihis bit is set, the SCSI bus 
inputs are logically isolated from die SCSI bus. 

Bit 5 Reserved 

Bit 4 Reserved 

Bit 3 DBLEN (SCLK Doubler Enable) 

This bit, when reset, powers down die internal 
clock doubler circuit, which doubles the SCLK 
40 MHz clock to an internal 80 MHz SCSI 
clock required for Wide Ultra SCSI operation. 
Both the SCLK Doubler Enable DBLEN and 
SCLK Double Select DBLSEL bits must be 
set in either SCSI function to get the internal 
80 MHz SCSI clock. 


Bit 2 DBLSEL (SCLK Doubler Select) 

This bit, when set, selects the ouqiut of the 
internal clock doubler for use as the internal 
SCSI clock. When reset, this bit selects die 
clock presented on SCLK for use as the inter¬ 
nal SCSI clock. 
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Bits 1-0 Reserved 


The SYM53C876 SCSI clock doubler doubles a 

40 MHz SCSI clock, increasing the frequency to 

80 MHz. Follow these steps to use the clock dou¬ 
bler. 

1. Set the SCLK Doubler Enable bit (STESTl, 
bit 3). 

2. Wait 20 |is. 

3. Halt the SCSI clock by setting the Halt SCSI 
Clock bit (STEST3j bit 5). 

4. Set the clock conversion factor using the SCF 
and CCF fields in the SCNTL3 register. 

5. Set the SCLK Doubler Select bit (STESTl, 
bit 2). 

6. Clear the Halt SCSI clock bit. 


Register 4Eh 

SCSI Test Two (STEST2) 
ReadlWrite 


SCE 

ROF 

DIF 

SLB 

SZM 

AWS 

EXT 

LOW 

7 

6 

5 

4 

3 

2 

1 

0 

Default »> 

0 0 

0 

0 

0 

0 

0 

0 


Bit 7 SCE (SCSI Control Enable) 

Setting this bit allows assertion of all SCSI 
control and data lines through the SO CL and 
SODL registers regardless of whether the 
SYM53C876 SCSI function is configured as a 
target or initiator. 

Note: Do not set this bit during normal 

operation, since it could cause contention 
on the SCSI bus. It is included for 
diagnostic purposes only. 

Bit 6 ROF (Reset SCSI Offset) 

Setting this bit clears any outstanding synchro¬ 
nous SREQ/SACK offset. Set this bit, if a 
SCSI gross error condition occurs, to clear the 
offset when a synchronous transfer does not 
complete successfully. The bit automatically 
clears itself after resetting the synchronous off¬ 
set. 

Bit 5 DIF 

Setting this bit allows the SYM53C876 SCSI 
function to interface properly to external dif¬ 
ferential transceivers. Its only real effect is to 
tristate the SBSY/, SSEL/, and SRST/ pads for 
use as pure inputs. Clearing this bit enables 
single-ended operation. Set this bit in the ini¬ 
tialization routine if the differential pair inter¬ 
face is used. 

Bit 4 SLB (SCSI Loopback Mode) 

Setting this bit allows the SYM53C876 SCSI 
function to perform SCSI loopback diagnos¬ 
tics. That is, it enables the SCSI core to simul¬ 
taneously perform as both initiator and target. 
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Bit 3 SZM (SCSI High-Impedance Mode) 

Setting this bit places all the open-drain 
48 mA SCSI drivers into a high-impedance 
State. This is to allow internal loopback mode 
operation without affecting the SCSI bus. 

Bit 2 AWS (Always Wide SCSI) 

When this bit is set, all SCSI information 
transfers are done in 16-bit wide mode. This 
includes data, message, command, status and 
reserved phases. Normally, deassert this bit 
since 16-bit wide message, command, and sta¬ 
tus phases are not supported by the SCSI spec¬ 
ifications. 

Bit 1 EXT (Extend SREQ/SACK 
Filtering) 

Sjmibios Logic TolerANT SCSI receiver tech¬ 
nology includes a special digital filter on the 
SREQ/ and SACK/ pins which causes the dis¬ 
regarding of glitches on deasserting edges. Set¬ 
ting this bit increases the filtering period firom 
30ns to 60ns on the deasserting edge of the 
SREQ/ and SACK/ signals. 

Note: Never set this bit during fast SCSI (greater 
than 5M transfers per second) operations, 
because a valid assertion could be treated 
as a glitch. 

Bit 0 LOW (SCSI Low level Mode) 

Setting this bit places the SYM53C876 SCSI 
fimction in low level mode. In this mode, no 
DAIA operations occur, and no SCRIPTS exe¬ 
cute. Arbitration and selection may be per¬ 
formed by setting the start sequence bit as 
described in the SCNTLO register. SCSI bus 
transfers are performed by manually asserting 
and polling SCSI signals. Clearing this bit 
allows instructions to be executed in SCSI 
SCRIPTS mode. 

Note: It is not necessary to set this bit for access 
to the SCSI bit-level registers (SODL, 
SBCL, and input registers). 


Register 4Fh 

SCSI Test Three (STEST3) 
ReadlWrite 


TE 

STR 

HSC 

DSI 

DIFF 

HM 

CSF 

STW 

7 

6 

5 

4 

3 

2 

1 

0 

Default »> 

0 0 

0 

0 

X 

0 

0 

0 


Bit 7 TE (TolerANT Enable) 

Setting this bit enables the active negation por¬ 
tion of Symbios Logic TolerANT technology. 
Active negation causes the SCSI Request, 
Acknowledge, Data, and Parity signals to be 
actively deasserted, instead of relying on exter¬ 
nal pull-ups, when the SYM53C876 SCSI 
function is driving these signals. Active deas¬ 
sertion of these signals occurs only when the 
SYM53C876 SCSI function is in an informa¬ 
tion transfer phase. When operating in a differ¬ 
ential environment or at fast SCSI timings, 
TolerANT Active negation should be enabled 
to improve setup and deassertion times. Active 
negation is disabled after reset or when this bit 
is cleared. For more information on Symbios 
Logic TolerANT technology, see Chapter 1. 

Note: Set this bit if the Enable Ultra SCSI bit in 
SCNTL3 is set. 

Bit 6 STR (SCSI FIFO Test Read) 

Setting this bit places the SCSI core into a test 
mode in which the SCSI FIFO is easily read. 
Reading the least significant byte of the SODL 
register causes the FIFO to unload. The func¬ 
tions are summarized in the table below. 


Register 

Name 

Register 

Operation 

FIFO Bits 

FIFO 

Function 

SODL 

Read 

15-0 

Unload 

SODLO 

Read 

7-0 

Unload 

SODLl 

Read 

15-8 

None 
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Bit 5 HSC (Halt SCSI Clock) 

Asserting this bit causes the internal divided 
SCSI clock to come to a stop in a glitchless 
manner. This bit is used for test purposes or to 
lower Ij)i 5 during a power down mode. 

Bit 4 DSI (Disable Single Initiator 
Response) 

If this bit is set, the SYM53C876 SCSI func¬ 
tion ignores all bus-initiated selection attempts 
that employ the single-initiator option from 
SCSI-1. In order to select the SYM53C876 
SCSI function while this bit is set, the 
SYM53C876 SCSI fimction’s SCSI ID and 
the initiator’s SCSI ID must both be asserted. 
Assert this bit in SCSI-2 systems so that a sin¬ 
gle bit error on the SCSI bus is not interpreted 
as a single initiator response. 

Bit 3 DIFF (DIFFSENSE Sense) 

If this bit is reset, the correct cable type is con¬ 
nected for differential operation. If this bit is 
set, a single ended cable is connected to the 
device’s DIFFSENSE pin. 

Bit 2 TTM (Timer Test Mode) 

Asserting this bit facilitates testing of the selec¬ 
tion time-out, general purpose, and hand- 
shake-to-handshake timers by greatly reducing 
all three time-out periods. Setting this bit starts 
all three timers and if the respective bits in the 
SIENl register are asserted, the SYM53C876 
SCSI function generates interrupts at time¬ 
out. This bit is intended for internal manufac¬ 
turing diagnosis and should not be used. 

Bit 1 CSF (Clear SCSI FIFO) 

Setting this bit causes the “full flags” for the 
SCSI FIFO to be cleared. This empties the 
FIFO. This bit is self-resetting. In addition to 
the SCSI FIFO pointers, the SIDL, SODL, 
and SODR full bits in the SSTATO and 
SSTAT2 are cleared. 


Bit 0 STW (SCSI FIFO Test Write) 

Setting this bit places the SCSI core into a test 
mode in which the FIFO is easily read or writ¬ 
ten. While this bit is set, writes to the least sig¬ 
nificant byte of the SODL register cause the 
entire word contained in this register to be 
loaded into the FIFO. Writing the least signifi¬ 
cant byte of the SODL register causes the 
FIFO to load. These functions are summarized 
in the table below. 


Register 

Name 

Register 

Operation 

FIFO Bits 

FiFO 

Function 

SODL 

Write 

15-0 

Load 

SODLO 

Write 

7-0 

Load 

SODLl 

Write 

15-8 

None 
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Register 50h~51h 

SCSI Input Data Latch (SIDL) 

Read Only 

This register is used primarily for diagnostic test¬ 
ing, programmed I/O operation, or error recovery. 
Data received from the SCSI bus can be read from 
this register. Data can be written to the SODL reg¬ 
ister and then read back into the 53C885 by read¬ 
ing this register to allow loopback testing. When 
receiving SCSI data, the data flows into this regis¬ 
ter and out to the host FIFO. This register differs 
from the SBDL register; SIDL contains latched 
data and the SBDL always contains exactly what is 
currendy on the SCSI data bus. Reading this regis¬ 
ter causes the SCSI parity bit to be checked, and 
causes a parity error interrupt if the data is not 
valid. The power-up values are indeterminate. 


Registers 54h-55h 

SCSI Output Data Latch (SODL) 

ReadlWrite 

This register is used primarily for diagnostic test¬ 
ing or programmed I/O operation. Data written to 
this register is asserted onto the SCSI data bus by 
setting the Assert Data Bus bit in the SCNTLl 
register. This register is used to send data via pro¬ 
grammed FO. Data flows through this register 
when sending data in any mode. It is also used to 
write to the synchronous data FIFO when testing 
the chip. The power-up value of this register is 
indeterminate. 
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Registers 58h-59h 

SCSI Bus Data Lines (SBDL) 

Read Only 

This register contains the SCSI data bus status. 
Even though the SCSI data bus is active low, these 
bits are active high. The signal status is not latched 
and is a true representation of exactly what is on 
the data bus at the time the register is read. This 
register is used when receiving data via pro¬ 
grammed I/O. This register can also be used for 
diagnostic testing or in low level mode. The power- 
up value of this register is indeterminate. 


Registers 5Ch-5Fh 

Scratch Register B (SCRATCHB) 

ReadlWrite 

This is a general purpose user definable scratch 
pad register. Apart from CPU access, only Register 
Read/Write and Memory Moves directed at the 
SCRATCH register alter its contents. When bit 3 
in the CTEST2 register is set, this register con¬ 
tains the base address for the 4 KB internal RAM. 
Setting CTEST2 bit 3 only causes the base 
address to appear in the SCRATCHB register; any 
information previously in the register remains 
intact. Any writes to this register while the bit is set 
pass through to the actual SCRATCHB register. 
The power-up values are indeterminate. 
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Registers 60h-7Fh 
Scratch Registers G-J 
(SCRATCHC-SCRATCHJ) 

ReadJWrite 

These registers are general-purpose scratch regis¬ 
ters for user-defined functions. They are accessible 
through Read-Modify-Write functions. 
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Chapter 5 

SCSI SCRIPTS Instruction Set 


After power up and initialization, the SYM53C876 
can operate in the low level register interface 
mode, or use SCSI SCRIPTS. 

With the low level register interface, the user has 
access to the DMA control logic and the SCSI bus 
control logic. An external processor has access to 
the SCSI bus signals and the low level DMA sig¬ 
nals, which allows creation of complicated board 
level test algorithms. The low level interface is use¬ 
ful for backward compatibility with SCSI devices 
that require certain unique timings or bus 
sequences to operate properly. Another feature 
allowed at the low level is loopback testing. In 
loopback mode, the SCSI core can be directed to 
talk to the DMA core to test internal data paths all 
the way out to the chip’s pins. 

The follovidng sections describe the benefits and 
use of SCSI SCRIPTS. 


SCSI SCRIPTS 

To operate in the SCSI SCRIPTS mode, the 
SYM53C876 requires only a SCRIPTS start 
address. The start address must be at a dword 
(four byte) botmdary. This aligns all the following 
SCRIPTS at a dword boundary since all 
SCRIPTS are 8 or 12 bytes long. Instructions are 
fetched until an interrupt instruction is encoun¬ 
tered, or imtil an unexpected event (such as a 
hardware error) causes an interrupt to the external 
processor. 

Once an interrupt is generated, the SYM53C876 
halts all operations until the interrupt is serviced. 
Then, the start address of the next SCRIPTS 
instruction is written to the DMA SCRIPTS 
Pointer register to restart the automatic fetching 
and execution of instructions. 


In the SCSI SCRIPTS mode the SYM53C876 is 
allowed to make decisions based on the status of 
the SCSI bus, which frees the microprocessor from 
servicing the numerous interrupts inherent in I/O 
operations. 

Given the rich set of SCSI oriented features 
included in the instruction set, and the ability to 
reenter the SCSI algorithm at any point, this high 
level interface is all that is required for both normal 
and exception conditions. Switching to low level 
mode for error recovery is not required. 

The following types of SCRIPTS instructions are 
implemented in the SYM53C876: 

■ Block Move—used to move data between the 
SCSI bus and memory 

■ I/O or Read/Write—causes the SYM53C876 
to trigger common SCSI hardware sequences, 
or to move registers 

■ Transfer Control—allows SCRIPTS 
instructions to make decisions based on real 
time SCSI bus conditions 

■ Memory Move—causes the SYM53C876 to 
execute block moves between different parts of 
main memory 

■ Load and Store—provides a more efficient way 
to move data to/from memory from/to an 
internal register in the chip without using the 
Memory Move instruction 

Each instruction consists of two or three 32-bit 
words. The first 32-bit word is always loaded into 
the DCMD and DBC registers, the second into 
the DSPS register. The third word, used only by 
Memory Move instructions, is loaded into the 
TEMP shadow register. In an indirect I/O or Move 
instruction, the first two 32-bit op code fetches are 
followed by one or two more 32-bit fetch cycles. 
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Sample Operation 

The following example describes execution of a 

SCRIPTS Block Move instruction. 

1. The host CPU, through programmed I/O, 
gives the DMA SCRIPTS Pointer (DSP) 
register (in the Operating Register file) the 
starting address in main memory that points to 
a SCSI SCRIPTS program for execution. 

2. Loading the DSP register causes the 
SYM53C876 to fetch its first instruction at the 
address just loaded. This fetch is from main 
memory or the internal RAM, depending on 
the address. 

3. The SYM53C876 typically fetches two dwords 
(64 bits) and decodes the high order byte of 
the first dword as a SCRIPTS instruction. If 
the instruction is a Block Move, the lower three 
bytes of the first dword are stored and 
interpreted as the number of bytes to move. 
The second dword is stored and interpreted as 
the 32-bit beginning address in main memory 
to which the move is directed. 

4. For a SCSI send operation, the SYM53C876 
waits until there is enough space in the DMA 
FIFO to transfer a programmable size block of 
data. For a SCSI receive operation, it waits 
until enough data is collected in the DMA 
FIFO for transfer to memory. At this point, the 
SYM53C876 requests use of the PCI bus 
again to transfer the data. 

5. When the SYM53C876 is granted the PCI 
bus, it executes (as a bus master) a burst 
transfer (programmable size) of data, 
decrements the internally stored remaining 
byte count, increments the address pointer, 
and then releases the PCI bus. The 
SYM53C876 stays off the PCI bus until the 
FIFO can again hold (for a write) or has 
collected (for a read) enough data to repeat the 
process. 


The process repeats imtil the internally stored byte 
count has reached zero. The SYM53C876 releases 
the PCI bus and then performs another SCRIPTS 
instruction fetch cycle, using the incremented 
stored address maintained in the DMA SCRIPTS 
Pointer register. Execution of SCRIPTS instruc¬ 
tions continues until an error condition occurs or 
an interrupt SCRIPTS instruction is received. At 
this point, the SYM53C876 interrupts the host 
CPU and waits for further servicing by the host 
system. It can execute independent Block Move 
instructions specifying new byte counts and start¬ 
ing locations in main memory. In this manner, the 
SYM53C876 performs scatter/gather operations 
on data without requiring help fi*om the host pro¬ 
gram, generating a host interrupt, or programming 
of an external DMA controller. 
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Write DSP 


Fetch 

SCRIPTS 


SYM53C876 SCSI 
Bus 


(Data is not fetched across system 
bus if internal RAM is enabled) 


Figure 5-1: SCRIPTS Overview 
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Block Move Instructions 

For Block Move instructions, bits 5 and 4 (SIOM 
and DIOM) in the DMODE register determine 
whether the source/destination address resides in 
memory or I/O space. When data is moved onto 
the SCSI bus, SIOM controls whether that data 
comes from I/O or memory space. When data is 
moved off of the SCSI bus, DIOM controls 
whether that data goes to I/O or memory space. 

First Dword 

Bits 31-30 Instruction Type-Block Move 

Bit 29 Indirect Addressing 

When this bit is cleared, user data is moved to 
or from the 32-bit data start address for the 
Block Move instruction. The value is loaded 
into the chip’s address register and incre¬ 
mented as data is transferred. The address of 
the data to move is in the second dword of this 
instruction. 

When set, the 32-bit user data start address for 
the Block Move is the address of a pointer to 
the actual data buffer address. The value at the 
32-bit start address is loaded into the chip’s 
DNAD register via a third longword fetch (4- 
byte transfer across the host computer bus). 


Direct 

The byte count and absolute address are as 
follows. 


Command 

Byte Count 

Address of Data 


Indirect 

Use the fetched byte count, but fetch the data 
address from the address in the instruction. 


Once the data pointer address is loaded, it is 
executed as when the chip operates in the 
direct mode. This indirect feature allows speci¬ 
fication of a table of data buffer addresses. 
Using the SCSI SCRIPTS compiler, the table 
offset is placed in the script at compile time. 
Then at the actual data transfer time, the off¬ 
sets are added to the base address of the data 
address table by the external processor. The 
logical I/O driver builds a structure of 
addresses for an I/O rather than treating each 
address individually. 

Note: It is not permitted to use indirect and table 
indirect addressing simultaneously; use 
only one addressing method at a time. 

Bit 28 Table Indirect 

When this bit is set, the 24-bit signed value in 
the start address of the move is treated as a rel¬ 
ative displacement from the value in the DSA 
register. Both the transfer count and the 
source/destination address are fetched from 
this address. 

Use the signed integer offset in bits 23-0 of the 
second four bytes of the instruction, added to 
the value in the DSA register, to fetch first the 
byte count and then the data address. The 
signed value is combined with the data struc¬ 
ture base address to generate the physical 
address used to fetch values from the data 
structure. Sign-extended values of all ones for 
negative values are allowed, but bits 31-24 are 
ignored. 


Command 

Not Used 

Don’t Care 

Table Offset 


Note: It is not permitted to use indirect and table 
indirect addressing simultaneously; use 
only one addressing method at a time. 


Command 

Byte Count 

Address of Pointer to Data 
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DCMD Register 


31 30 29 28 27 26 25 24 


DBC Register 


23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 


■■'iJr.i 


1 


I/O 

C/D 24-bit Block Move byte counter 

MSG/ 

*— Op Code 

'—Table Indirect Addressing 
'— Indirect Addressing (53C700 compatible) 

0 - Instruction Type - Block Move 
'— 0 - Instruction Type - Block Move 


DSPS Register 

31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 876543210 


Figure 5-2: Block Move Instruction Register 


Prior to the start of an I/O, load the Data 
Structure Base Address register (DSA) with 
the base address of the I/O data structure. Any 
address on a long word boundary is allowed. 

After a Table Indirect op code is fetched, the 
DSA is added to the 24-bit signed offset value 
from the op code to generate the address of the 
required data; both positive and negative off¬ 
sets are allowed. A subsequent fetch from that 
address brings the data values into the chip. 

For a MOVE instruction, the 24-bit byte 
count is fetched from system memory. Then 
the 32-bit physical address is brought into the 
SYM53C876. Execution of the move begins at 
this point. 


SCRIPTS can directly execute operating sys¬ 
tem I/O data structures, saving time at the 
beginning of an I/O operation. The I/O data 
structure can begin on any longword boundary 
and may cross system segment boundaries. 

There are two restrictions on the placement of 
pointer data in system memory: The eight 
bytes of data in the MOVE instruction must be 
contiguous, as shown below; and indirect data 
fetches are not available during execution of a 
Memory-to-Memory DMA operation. 


00 

Byte Count 

Physical Data Address 
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Bit 27 Op Code 

This 1-bit field defines the instruction to exe¬ 
cute as a block move (MOVE). 


Target Mode 


OPC 

Instruction Defined 

0 

MOVE 

1 

CHMOV 


1. The SYM53C876 verifies that it is connected 
to the SCSI bus as a target before executing 
this instruction. 

2. The SYM53C876 asserts the SCSI phase 
signals (SMSG/, SC_D/j and SI_0/) as defined 
by the Phase Field bits in the instruction. 

3. If die instruction is for the command phase, 
the SYM53C876 receives the first command 
byte and decodes its SCSI Group Code. 

a. If the SCSI Group Code is either Group 0, 
Group 1, Group 2, or Group 5, then the 
SYM53C876 overwrites the DEC register 
with the length of the Command 
Descriptor Block: 6,10, or 12 bytes. 

b. If the Vendor Unique Enhancement 0 
(VUEO) bit (SCNTL2, bit 1) is clear and 
the SCSI group code is a vendor unique 
code, the SYM53C876 overwrites the 
DEC register with the length of the 
Command Descriptor Block: 6,10, or 12 
bytes. If the VUEO bit is set, the 
SYM53C876 receives the number of b 5 ^es 
in the byte count regardless of the group 
code. 

c. If any other Group Code is received, the 
DEC register is not modified and the 
SYM53C876 requests the number of bytes 
specified in the DEC register. If the DEC 
register contains OOOOOOh, an illegal 
instruction interrupt is generated. 

4. The SYM53C876 transfers the number of 
bytes specified in the DEC register starting at 
the address specified in the DNAD register. If 


the Op Code bit is set and a data transfer ends 
on an odd byte boundary, the SYM53C876 
stores the last byte in the SCSI Wide Residue 
Data Register during a receive operation. This 
byte is combined with the first byte from the 
subsequent transfer so that a wide transfer can 
complete, 

5. If the SATN/ signal is asserted by the initiator 
or a parity error occurred during the transfer, it 
is possible to halt the transfer and generate an 
interrupt. The Disable Halt on Parity Error or 
ATN bit in the SCNTLl register controls 
whether the SYM53C876 halts on these 
conditions immediately, or waits until 
completion of the current Move. 


Initiator Mode 

OPC 

instruction Defined 

0 

CHMOV 

1 

MOVE 


1. The SYM53C876 verifies that it is connected 
to the SCSI bus as an initiator before executing 
this instruction. 

2. The SYM53C876 waits for an unserviced 
phase to occur. An unserviced phase is defined 
as any phase (with SREQ/ asserted) for which 
the SYM53C876 has not yet transferred data 
by responding with a SACK/. 

3. The SYM53C876 compares the SCSI phase 
bits in the DCMD register with the latched 
SCSI phase lines stored in the SSTATl 
register. These phase lines are latched when 
SREQ/ is asserted. 

4. If the SCSI phase bits match the value stored 
in the SSTATl register, the SYM53C876 
transfers the number of bytes specified in the 
DEC register starting at the address pointed to 
by the DNAD register. If the op code bit is 
cleared and a data transfer ends on an odd byte 
boimdary, the SYM53C876 stores the last byte 
in the SCSI Wide Residue Data Register 
during a receive operation, or in the SCSI 
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Output Data Latch Register during a send 
operation. This byte is combined with the first 
byte from the subsequent transfer so that a 
wide transfer can complete. 

5. If the SCSI phase bits do not match the value 
stored in the SSTATl register, the 
SYM53C876 generates a phase mismatch 
interrupt and the instruction is not executed. 

6. During a Message-Out phase, after the 
SYM53C876 has performed a select with 
Attention (or SATN/ is manually asserted with 
a Set ATN instruction), the SYM53C876 
deasserts SATN/ during the final SREQ/SACK 
handshake. 

7. When the SYM53C876 is performing a block 
move for Message-In phase, it does not 
deassert the SACK/ signal for the last SREQ/ 
SACK handshake. Clear the SACK signal 
using the Clear SACK I/O instruction. 

Bits 26-24 SCSI Phase 

This 3-bit field defines the desired SCSI infor¬ 
mation transfer phase. When the SYM53C876 
operates in initiator mode, these bits are com¬ 
pared with the latched SCSI phase bits in the 
SSTATl register. When the SYM53C876 
operates in target mode, it asserts the phase 
defined in this field. The following table 
describes the possible combinations and the 
corresponding SCSI phase. 


MSG 

C/D 

I/O 

SCSI Phase 

0 

0 

0 

Data-Out 

0 

0 

1 

Data-In 

0 

1 

0 

Command 

0 

1 

1 

Status 

1 

0 

0 

Reserved-Out 

1 

0 

1 

Reserved-In 

1 

1 

0 

Message-Out 

1 

1 

1 

Message-In 


Bits 23-0 Transfer Counter 

This 24-bit field specifies the number of data 
bytes to move between the SYM53C876 and 
system memory. The field is stored in the DEC 
register. When the SYM53C876 transfers data 
to/from memory, the DEC register is decre¬ 
mented by the number of bytes transferred. In 
addition, the DNAD register is incremented by 
the number of bytes transferred. This process is 
repeated until the DEC register is decremented 
to zero. At this time, the SYM53C876 fetches 
the next instruction. 

If bit 28 is set, indicating table indirect 
addressing, this field is not used. The byte 
count is instead fetched from a table pointed to 
by the DSA register. 

Second Dword 

Bits 31-0 Start Address 

This 32-bit field specifies the starting address 
of the data to move to/firom memory. This field 
is copied to the DNAD register. When the 
SYM53C876 transfers data to or from mem¬ 
ory, the DNAD register is incremented by the 
number of bytes transferred. 

When bit 29 is set, indicating indirect address¬ 
ing, this address is a pointer to an address in 
memory that points to the data location. When 
bit 28 is set, indicating table indirect address¬ 
ing, the value in this field is an offset into a 
table pointed to by the DSA. The table entry 
contains byte count and address information. 
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I/O Instructions 


First Dword 

Bits 31-30 Instruction Type - I/O Instruction 

Bits 29-27 Op Code 

The following Op Code bits have different 
meanings, depending on whether the 
SYM53C876 is operating in initiator or target 
mode. Op Code selections 101-111 are consid¬ 
ered Read/Write instructions, and are 
described in that section. 


Target Mode 


0PC2 

0PC1 

OPCO 

Instruction Defined 

0 

0 

0 

Reselect 

0 

0 

1 

Disconnect 

0 

1 

0 

Wait Select 

0 

1 

1 

Set 

1 

0 

0 

Clear 


Reselect Instruction 

1. The SYM53C876 arbitrates for the SCSI bus 
by asserting the SCSI ID stored in the SCID 
register. If it loses arbitration, it tries again 
during the next available arbitration cycle 
without reporting any lost arbitration status. 

2. If the SYM53C876 wins arbitration, it 
attempts to reselect the SCSI device whose ID 
is defined in the destination ID field of the 
instruction. Once the SYM53C876 wins 
arbitration, it fetches the next instruction from 
the address pointed to by the DSP register. 
This way the SCRIPTS can move on to the 
next instruction before the reselection 
completes. It continues executing SCRIPTS 
until a SCRIPT that requires a response from 
the initiator is encountered. 

3. If the SYM53C876 is selected or reselected 
before winning arbitration, it fetches the next 
instruction from the address pointed to by the 


32-bit jump address field stored in the DNAD 
register. Manually set the SYM53C876 to 
initiator mode if it is reselected, or to target 
mode if it is selected. 

Disconnect Instruction 

The SYM53C876 disconnects from the SCSI bus 
by deasserting all SCSI signal outputs. 

Wait Select Instruction 

1. If the SYM53C876 is selected, it fetches the 
next instruction from the address pointed to by 
the DSP register. 

2. If reselected, the SYM53C876 fetches the next 
instruction from the address pointed to by the 
32-bit jump address field stored in the DNAD 
register. Manually set the SYM53C876 to 
initiator mode when it is reselected. 

3. If the CPU sets the SIGP bit in the ISTAT 
register, the SYM53C876 aborts the Wait 
Select instruction and fetches the next 
instruction from the address pointed to by the 
32-bit jump address field stored in the DNAD 
register. 

Set Instruction 

When the SACK/ or SATN/ bits are set, the corre¬ 
sponding bits in the SOCL register are set. Do not 
set SACK/ or SATN/ except for testing purposes. 
When the target bit is set, the corresponding bit in 
the SCNTLO register is also set. When the carry 
bit is set, the corresponding bit in the Arithmetic 
Logic Unit (ALU) is set. 

Note: None of the signals are set on the SCSI bus 
in target mode. 

Clear Instruction 

When the SACK/ or SATN/ bits are set, the corre¬ 
sponding bits are cleared in the SOCL register. Do 
not set SACK/ or SATN/ except for testing pur¬ 
poses. When the target bit is set, the corresponding 
bit in the SCNTLO register is cleared. When the 
carry bit is set, the corresponding bit in the ALU is 
cleared. 

Note: None of the signals are reset on the SCSI 
bus in target mode. 
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^— DCMD Register —► 
31 30 29 28 27 26 25 24 


DBC Register 


23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 


7 


RES 


RES 


RES 


RES 

>— Set/Clear ATN/ 


^ Set/Clear ACK/ 

'— Set/Clear Target Mode 
— Set/Clear Carry 

— Encoded Destination IDO 
— Encoded Destination ID 1 
— Encoded Destination ID 2 
— Encoded Destination ID 3 
— Reserved 
— Reserved 
— Reserved 
— Reserved 
— Select with ATM/ 

— Table Indirect Mode 
— Relative Address Mode 
— Op Code bit 0 
— Op Code bit 1 
— Op code bit 2 
— 1 - Instruction Type - I/O 
— 0 - Instruction Type - I/O 


Second 32-bit word of the I/O instruction 
DSPSRegister 

31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 



32-bit Jump Address 


Figure 5-3: I/O Instruction Register 


SYM53C876 Data Manual 


5-9 
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Initiator Mode 


0PC2 

0PC1 

OPCO 

Instruction Defined 

0 

0 

0 

Select 

0 

0 

1 

Wait Disconnect 

0 

1 

0 

Wait Reselect 

0 

1 

1 

Set 

1 

0 

0 

Clear 


Select Instruction 

1. The SYM53C876 arbitrates for the SCSI bus 
by asserting the SCSI ID stored in the SCID 
register. If it loses arbitration, it tries again 
during the next available arbitration cycle 
without reporting any lost arbitration status. 

2. If the SYM53C876 wins arbitration, it 
attempts to select the SCSI device whose ID is 
defined in the destination ID field of the 
instruction. Once the SYM53C876 wins 
arbitration, it fetches the next instruction from 
the address pointed to by the DSP register. 
This way the SCRIPTS can move to the next 
instruction before the selection completes. It 
continues executing SCRIPTS imtil a SCRIPT 
that requires a response from the target is 
encountered. 

3. If the SYM53C876 is selected or reselected 
before winning arbitration, it fetches the next 
instruction from the address pointed to by the 
32-bit jump address field stored in the DNAD 
register. Manually set the SYM53C876 to 
initiator mode if it is reselected, or to target 
mode if it is selected. 

4. If the Select with SATN/ field is set, the 
SATN/ signal is asserted during the selection 
phase. 

Wait Disconnect Instruction 

The SYM53C876 waits for the target to perform a 
“legal” disconnect from the SCSI bus. A “legal” 
disconnect occurs when SBSY/ and SSEL/ are 
inactive for a minimum of one Bus Free delay (400 
ns), after the SYM53C876 receives a Disconnect 
Message or a Command Complete Message. 


Wait Reselect Instruction 

1. If the SYM53C876 is selected before being 
reselected, it fetches the next instruction from 
the address pointed to by the 32-bit jump 
address field stored in the DNAD register. 
Manually set the SYM53C876 to target mode 
when it is selected. 

2. If the SYM53C876 is reselected, it fetches the 
next instruction from the address pointed to by 
the DSP register. 

3. If the CPU sets the SIGP bit in the ISTAT 
register, the SYM53C876 aborts the Wait 
Reselect instruction and fetches the next 
instruction from the address pointed to by the 
32-bit jump address field stored in the DNAD 
register. 

Set Instruction 

When the SACK/ or SATN/ bits are set, the corre¬ 
sponding bits in the SOCL register are set. When 
the target bit is set, the corresponding bit in the 
SCNTID register is also set. When the carry bit is 
set, the corresponding bit in the ALU is set. 

Clear Instruction 

When the SACK/or SATN/ bits are set, the corre¬ 
sponding bits are cleared in the SOCL register. 
When the target bit is set, the corresponding bit in 
the SCNTLO register is cleared. When the carry 
bit is set, the corresponding bit in the ALU is 
cleared. 

Bit 26 Relative Addressing Mode 

When this bit is set, the 24-bit signed value in 
the DNAD register is used as a relative dis¬ 
placement from the current DSP address. Use 
this bit only in conjunction with the Select, 
Reselect, Wait Select, and Wait Reselect 
instructions. The Select and Reselect instruc¬ 
tions can contain an absolute alternate jump 
address or a relative transfer address. 

Bit 25 Table Indirect Mode 

When this bit is set, the 24-bit signed value in 
the DBC register is added to the value in the 
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DSA register, used as an offset relative to the 
value in the Data Structure Base Address 
(DSA) register. The SCNTL3 value, SCSI ID, 
synchronous offset and synchronous period are 
loaded from this address. Prior to the start of 
an I/O, load the DSA with the base address of 
the I/O data structure. Any address on a long- 
word boundary is allowed. After a Table Indi¬ 
rect op code is fetched, the DSA is added to 
the 24-bit signed offset value from the op code 
to generate the address of the required data. 
Both positive and negative offsets are allowed. 
A subsequent fetch from that address brings 
the data values into the chip. 

SCRIPTS can directly execute operating sys¬ 
tem I/O data structures, saving time at the 
beginning of an I/O operation. The I/O data 
structure can begin on any dword boundary 
and may cross system segment boundaries. 
There are two restrictions on the placement of 
data in system memory: 

1. The I/O data structure must lie within the 8 
MB above or below the base address. 

2. An I/O command structure must have all four 
bytes contiguous in system memory, as shown 
below. The offset/period bits are ordered as in 
the SXFER register. The configuration bits are 
ordered as in the SCNTL3 register. 


Config 

ID 

Offset/ 

period 

(00) 


Use this bit only in conjunction with the 
Select, Reselect, Wait Select, and Wait Reselect 
instructions. It is allowable to set bits 25 and 
26 individually or in combination: 



Bit 25 

Bit 26 

Direct 

0 

0 

Table Indirect 

0 

1 

Relative 

1 

0 

Table Relative 

1 

1 


Direct 

Uses the device ID and physical address in the 
instruction. 


Command 

ID 

Not Used 

Not Used 1 

Absolute Alternate Address 


Table Indirect 

Uses the physical jump address, but fetches data 
using the table indirect method. 


Command 


Table Offset 


Absolute Alternate Address 


Relative 

Uses the device ID in the instruction, but treats 
the alternate address as a relative jump 


Command 

ID 

Not Used 

Not 




Used 


Alternate Jump Offset 


Table Relative 

Treats the alternate jump address as a relative 
jump and fetches the device ID, synchronous off¬ 
set, and synchronous period indirectly. Adds the 
value in bits 23-0 of the first four bytes of the 
SCRIPTS instruction to the data structure base 
address to form the fetch address. 


Command 

Table Offset 

Alternate Jump Offset 


Bit 24 Select with ATN/ 
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This bit specifies whether SATN/ is asserted 
during the selection phase when the 
SYM53C876 is executing a Select instruction. 
When operating in initiator mode, set this bit 
for the Select instruction. If this bit is set on 
any other I/O instruction, an illegal instruction 
interrupt is generated. 

Bit 23-20 Reserved 

Bits 19-16 Encoded SCSI Destination ID 

This 4-bit field specifies the destination SCSI 
ID for an I/O instruction. 

Bits 15-11 Reserved 

Bit 10 Set/Clear Carry 

This bit is used in conjunction with a Set or 
Clear instruction to set or clear the Carry bit. 
Setting this bit with a Set instruction asserts 
the Carry bit in the ALU. Setting this bit with a 
Clear instruction deasserts the Carry bit in the 
ALU. 

Bit 9 Set/Clear Target Mode 

This bit is used in conjunction with a Set or 
Clear instruction to set or clear target mode. 
Setting this bit with a Set instruction config¬ 
ures the SYM53C876 as a target device (this 
sets bit 0 of the SCNTLO register). Setting this 
bit with a Clear instruction configures the 
SYM53C876 as an initiator device (this clears 
bit 0 of the SCNTLO register). 

Bits 8-7 Reserved 

Bit 6 Set/Clear SACK/ 

Bits 5-4 Reserved 

Bit 3 Set/Clear SATN/ 


These two bits are used in conjunction with a 
Set or Clear instruction to assert or deassert 
the corresponding SCSI control signal. Bit 6 
controls the SCSI SACK/ signal. Bit 3 controls 
the SCSI SATN/ signal. 

Setting either of these bits sets or resets the 
corresponding bit in the SO CL register, 
depending on the instruction used. The Set 
instruction is used to assert SACK/ and/or 
SATN/ on the SCSI bus. The Clear instruction 
is used to deassert SACK/ and/or SATN/ on 
the SCSI bus. 

Since SACK/ and SATN/ are initiator signals, 
they are not asserted on the SCSI bus unless 
the SYM53C876 is operating as an initiator or 
the SCSI Loopback Enable bit is set in the 
STEST2 register. 

The Set/Clear SCSI ACK/ATN instruction is 
used after message phase Block Move opera¬ 
tions to give the initiator the opportimity to 
assert attention before acknowledging the last 
message b 5 rte. For example, if the initiator 
wishes to reject a message, it issues an Assert 
SCSI ATN instruction before a Clear SCSI 
ACK instruction. 

Bits 2-0 Reserved 


Second Dword 

Bits 31-0 Start Address 

This 32-bit field contains the memory address 
to fetch the next instruction if the selection or 
reselection fails. 

If relative or table relative addressing is used, 
this value is a 24-bit signed offset relative to the 
current DSP register value. 
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Read/Write Instructions 

The Read/Write instruction supports addition, 
subtraction, and comparison of two separate values 
within the chip. It performs the desired operation 
on the specified register and the SFBR register, 
then stores the result back to the specified register 
or the SFBR. If the COM bit (DCNTL, bit 0) is 
cleared, ReadAJ^rite instruction can not be used. 


First Dword 

Bits 31-30 Instruction Type - ReadyWrite 
Instruction 

The Read/Write instruction uses operator bits 
26 through 24 in conjunction with the op code 
bits to determine which instruction is currently 
selected. 




Reserved 
(must be 0) 


DSPS Register 

31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 



Figure 5-4: Read/Write Instruction Register 
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Bits 29-27 Op Code 

The combinations of these bits determine if the 
instruction is a Read/Write or an I/O instruc¬ 
tion. Op codes 000 through 100 are considered 
I/O instructions. 

Bits 26-24 Operator 

These bits are used in conjunction with the op 
code bits to determine which instruction is cur¬ 
rently selected. Refer to table 6-1 for field defi¬ 
nitions. 

Bit 23 Use data 8/SFBR 

When this bit is set, SFBR is used instead of 
the dataS value during a Read-Modify-Write 
instruction (see Table 5-1).This allows the user 
to add two register values. 

Bits 22-16 Register Address - A(6-0) 

It is possible to change register values from 
SCRIPTS in read-modify-write cycles or move 
to/firom SFBR cycles. A(6-0) selects an 8-bit 
source/destination register within the 
SYM53C876. 

Bits 15-8 Immediate Data 

This 8-bit value is used as a second operand in 
logical and arithmetic functions. 

Bits 7-0 Reserved 


Second Dword 

Bits 31-0 Destination Address 

This field contains the 32-bit destination 
address where the data is to move. 


Read-Modify-Write Cycles 

During these cycles the register is read, the selected 
operation is performed, and the result is written 
back to the source register. 

The Add operation is used to increment or decre¬ 
ment register values (or memory values if used in 
conjunction with a Memory-to-Register Move 
operation) for use as loop counters. 

Subtraction is not available when SFBR is used 
instead of data8 in the instruction syntax. To sub¬ 
tract one value from another when using SFBR, 
first XOR the value to subtract (subtrahend) with 
OxFF, and add 1 to the resulting value. This creates 
the 2*s compliment of the subtrahend. The two val¬ 
ues are then added to obtain the difference. 


Move to/from SFBR Cycles 

All operations are read-modify-writes. However, 
two registers are involved, one of which is always 
the SFBR. The possible functions of this instruc¬ 
tion are: 

■ Write one byte (value contained within the 
SCRIPTS instruction) into any chip register. 

■ Move to/ffom the SFBR from/to any other 
register. 

■ Alter the value of a register with AND/OR/ 
ADD/XOR/SHIFT LEFT/SHIFT RIGHT 
operators. 

■ After moving values to the SFBR, the compare 
and jump, call, or similar instructions are used 
to check the value. 

■ A Move-to-SFBR followed by a Move-ffom- 
SFBR is used to perform a register to register 
move. 
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Table 5-1: 

ReadAVrite Instructions 


Operator 

Op Code 111 

Read Modify Write 

Op Code 110 

Move to SFBR 

Op Code 101 

Move from SFBR 

000 

Move data into register. 
Syntax: “Move dataS to 
RegA” 

Move data into SFBR regis¬ 
ter. Syntax: “Move dataS to 
SFBR” 

Move data into register. 

Syntax: “Move dataS to 

RegA” 

001* 

Shift register one bit to the 
left and place the result in 
the same register. Syntax: 
“Move RegA SHL RegA” 

Shift register one bit to the 
left and place the result in 
the SFBR register. Syntax: 
“Move RegA SHL SFBR” 

Shift the SFBR register one 
bit to the left and place tlie 
result in the register. Syntax: 
“Move SFBR SHL RegA” 

010 

OR data with register and 
place the result in the same 
register. Syntax: “Move 

RegA I dataS to RegA” 

OR data with register and 
place the result in the SFBR 
register. Syntax: “Move 

RegA 1 dataS to SFBR” 

OR data with SFBR and 
place the result in the regis¬ 
ter. S 5 mtax: “Move SFBR | 
dataS to RegA” 

on 

XOR data with register and 
place the result in the same 
register. Syntax: “Move 

RegA XOR dataS to RegA” 

XOR data with register and 
place the result in the SFBR 
register. Sjmtax: “Move 

RegA XOR dataS to SFBR” 

XOR data with SFBR and 
place the result in the regis¬ 
ter. Syntax: “Move SFBR 
XOR dataS to RegA” 

100 

AND data with register and 
place the result in the same 
register. Syntax: “Move 

RegA & dataS to RegA” 

AND data with register and 
place the result in the SFBR 
register. Syntax: “Move 

RegA & dataS to SFBR” 

AND data with SFBR and 
place the result in the regis¬ 
ter. Syntax; “Move SFBR & 
dataS to RegA” 

101* 

Shift register one bit to the 
right and place the result in 
the same register. Syntax: 
“Move RegA SHR RegA” 

Shift register one bit to the 
right and place the result in 
the SFBR register. Syntax: 
“Move RegA SHR SFBR” 

Shift the SFBR register one 
bit to the right and place the 
result in the register. Syntax: 
“Move SFBR SHR RegA” 

no 

Add data to register without 
carry and place the result in 
the same register. S 5 nitax: 
“Move RegA + dataS to 
RegA” 

Add data to register without 
carry and place the result in 
the SFBR register. Syntax: 
“Move RegA + dataS to 
SFBR” 

Add data to SFBR without 
carry and place the result in 
the register. Syntax: “Move 
SFBR + dataS to RegA” 

111 

Add data to register with 
carry and place the result in 
the same register. Syntax: 
“Move RegA + dataS to 

RegA with carry” 

Add data to register with 
carry and place the result in 
the SFBR register. Syntax: 
“Move RegA + dataS to 

SFBR with carry” 

Add data to SFBR with 
carry and place the result in 
the register. Syntax: “Move 
SFBR + dataS to RegA with 
carry” 


Notes: 

1. Substitute the desired register name or address for “RegA”in the syntax examples 

2. dataS indicates eight bits of data 

3. Use SFBR instead of dataS to add two register values. 

* Data is shifted through the Carry bit and the Carry bit is shifted into the data byte 
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Transfer Control 
Instructions 


First Dword 

Bits 31-30 Instruction Type - Transfer Con¬ 
trol Instruction 

Bits 29-27 Op Code 

This 3>bit field specifies the type of transfer 
control instruction to execute. All transfer con¬ 
trol instructions can be conditional. They can 
be dependent on a true/false comparison of the 
ALU Carry bit or a comparison of the SCSI 
information transfer phase with the Phase field, 
and/or a comparison of the First B 5 rte Received 
with the Data Compare field. Each instruction 
can operate in initiator or target mode. 


0PC2 

0PC1 

OPCO 

Instruction Defined 

0 

0 

0 

Jump 

0 

0 

1 

Call 

0 

1 

0 

Return 

0 

1 

1 

Interrupt 

1 

X 

X 

Reserved 


Jump Instruction 

1. The SYM53C876 can do a true/false 
comparison of the ALU carry bit, or compare 
the phase and/or data as defined by the Phase 
Compare, Data Compare and True/False bit 
fields. If the comparisons are true, the it loads 
the DSP register with the contents of the 
DSPS register. The DSP register now contains 
the address of the next instruction. 

2. If the comparisons are false, the SYM53C876 
fetches the next instruction firom the address 
pointed to by the DSP register, leaving the 
instruction pointer unchanged. 

Call Instruction 

1. The SYM53C876 can do a true/false 
comparison of the ALU carry bit, or compare 
the phase and/or data as defined by the Phase 
Compare, Data Compare, and True/False bit 
fields. If the comparisons are true, it loads the 
DSP register with the contents of the DSPS 
register and that address value becomes the 
address of the next instruction. 

When the SYM53C876 executes a Call 
instruction, the instruction pointer contained 
in the DSP register is stored in the TEMP reg¬ 
ister. Since the TEMP register is not a stack 
and can only hold one dword, nested call 
instructions are not allowed. 

2. If the comparisons are false, the SYM53C876 
fetches the next instruction firom the address 
pointed to by the DSP register and the 
instruction pointer is not modified. 
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Figure 5-5: Transfer Control Instruction 
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Transfer Control Instructions 
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Return Instruction 

1. The SYM53C876 can do a true/false 
comparison of the ALU carry bit, or compare 
the phase and/or data as defined by the Phase 
Compare, Data Compare, and True/False bit 
fields. If the comparisons are true, it loads the 
DSP register with the contents of the DSPS 
register. That address value becomes the 
address of the next instruction. 

When a Return instruction is executed, the 
value stored in the TEMP register is returned 
to the DSP register. The SYM53C876 does 
not check to see whether the Call instruction 
has already been executed. It does not gener¬ 
ate an interrupt if a Return instruction is exe¬ 
cuted without previously executing a Call 
instruction. 

2. If the comparisons are false, the SYM53C876 
fetches the next instruction from the address 
pointed to by the DSP register and the 
instruction pointer is not modified. 

Interrupt Instructions 

Interrupt 

a. The SYM53C876 can do a true/false 
comparison of the ALU carry bit, or 
compare the phase and/or data as defined 
by the Phase Compare, Data Compare, 
and True/False bit fields. If the 
comparisons are true, the SYM53C876 
generates an interrupt by asserting the 
IRQ/ signal. 

c. The 32-bit address field stored in the 
DSPS register (not DNAD as in 53C700) 
can contain a unique interrupt service 
vector. When servicing the interrupt, this 
unique status code allows the ISR to 
quickly identify the point at which the 
interrupt occurred. 

d. The SYM53C876 halts and the DSP 
register must be written to start any 
further operation. 
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Interrupt on-the-Fly 

a. The SYM53C876 can do a true/false 
comparison of the ALU carry bit or 
compare the phase and/or data as defined 
by the Phase Compare, Data Compare, and 
True/False bit fields. If the comparisons are 
true, and the Interrupt on the Fly bit 
(ISTAT bit 2) is set, the SYM53C876 
asserts the Interrupt on the Fly bit. 

Bits 26-24 SCSI Phase 

This 3-bit field corresponds to the three SCSI 
bus phase signals which are compared with the 
phase lines latched when SREQ/ is asserted. 
Comparisons can be performed to determine 
the SCSI phase actually being driven on the 
SCSI bus. The following table describes the 
possible combinations and their corresponding 
SCSI phase. These bits are only valid when the 
SYM53C876 is operating in initiator mode. 
Clear these bits when the SYM53C876 is oper¬ 
ating in the target mode. 


MSG 

C/D 

I/O 

SCSI Phase 

0 

0 

0 

Data-Out 

0 

0 

1 

Data-In 

0 

1 

0 

Command 

0 

1 

1 

Status 

1 

0 

0 

Reserved-Out 

1 

0 

1 

Reserved-In 

1 

1 

0 

Message-Out 

1 

1 

1 

Message-In 


Bit 23 Relative Addressing Mode 

When this bit is set, the 24-bit signed value in 
the DSPS register is used as a relative offset 
from the current DSP address (which is point¬ 
ing to the next instruction, not the one cur¬ 
rently executing). Relative mode does not apply 
to Return and Interrupt SCRIPTS. 


SYM53C8876 Data Manual 



PREUMINARY 
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Transfer Control Instructions 


Jump/Call an Absolute Address 

Start execution at the new absolute address. 


Command 

Condition Codes 

Absolute Alternate Address 


Jump/Call a Relative Address 
Start execution at the current address plus (or 
minus) the relative offset. 


Command 

Condition Codes 

Don’t Care 

Alternate Jump Offset 


The SCRIPTS program counter is a 32-bit 
value pointing to the SCRIPT currently under 
execution by the SYM53C876.The next 
address is formed by adding the 32-bit pro¬ 
gram counter to the 24-bit signed value of the 
last 24 bits of the Jump or Call instruction. 
Because it is signed (twos compliment), the 
jump can be forward or backward. 

A relative transfer can be to any address within 
a 16-MB segment. The program counter is 
combined with the 24-bit signed offset (using 
addition or subtraction) to form the new exe¬ 
cution address. 

SCRIPTS programs may contain a mixture of 
direct jumps and relative jumps to provide 
maximum versatility when writing SCRIPTS. 
For example, major sections of code can be 
accessed with far calls using the 32-bit physical 
address, then local labels can be called using 
relative transfers. If a SCRIPT is written using 
only relative transfers it does not require any 
run time alteration of physical addresses, and 
can be stored in and executed from a PROM. 

Bit 21 Carry Test 

When this bit is set, decisions based on the 
ALU carry bit can be made. True/False com¬ 
parisons are legal, but Data Compare and 
Phase Compare are illegal. 


Bit 20 Interrupt on the Fly 

When this bit is set, the interrupt instruction 
does not halt the SCRIPTS processor. Once 
the interrupt occurs, the Interrupt on the Fly 
bit (ISTAT bit 2) is asserted. 

Bit 19 Jump If True/False 

This bit determines whether the SYM53C876 
branches when a comparison is true or when a 
comparison is false. This bit applies to phase 
compares, data compares, and carry tests. If 
both the Phase Compare and Data Compare 
bits are set, then both compares must be true 
to branch on a true condition. Both compares 
must be false to branch on a false condition. 


Bit 19 

Result of 
Compare 

Action 

0 

False 

Jump Taken 

0 

True 

No Jump 

1 

False 

No Jump 

1 

True 

Jump Taken 


Bit 18 Compare Data 

WTien this bit is set, the first b 5 ^e received from 
the SCSI data bus (contained in SFBR regis¬ 
ter) is compared with the Data to be Com¬ 
pared Field in the Transfer Control instruction. 
The Wait for Valid Phase bit controls when this 
compare occurs. The Jump if True/False bit 
determines the condition (true or false) to 
branch on. 

Bit 17 Compare Phase 

When the SYM53C876 is in initiator mode, 
this bit controls phase compare operations. 
When this bit is set, the SCSI phase signals 
(latched by SREQ/) are compared to the Phase 
Field in the Transfer Control instruction. If 
they match, the comparison is true. The Wait 
for Valid Phase bit controls when the compare 
occurs. When the SYM53C876 is operating in 
target mode this bit, when set, tests for an 
active SCSI SATN/ signal. 
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Bit 16 Wait For Valid Phase 

If the Wait for Valid Phase bit is set, the 
SYM53C876 waits for a previously unserviced 
phase before comparing the SCSI phase and 
data. 

If the Wait for Valid Phase bit is clear, the 
SYM53C876 compares the SCSI phase and 
data immediately. 

Bits 15-8 Data Compare Mask 

The Data Compare Mask allows a SCRIPT to 
test certain bits within a data byte. During the 
data compare, if any mask bits are set the cor¬ 
responding bit in the SFBR data bjrte is 
ignored. For instance, a mask of 0111111 lb 
and data compare value of IXXXXXXXb 
allows the SCRIPTS processor to determine 
whether or not the high order bit is set while 
ignoring the remaining bits. 

Bits 7-0 Data Compare Value 

This 8-bit field is the data compared against 
the SCSI First Byte Received (SFBR) register. 
These bits are used in conjtmction with the 
Data Compare Mask Field to test for a particu¬ 
lar data value. If the COM bit (DCNTL, bit 0) 
is cleared, the value in the SFBR register may 
not be stable. In this case, do not use instruc¬ 
tions using this data compare value. 


Second Dword 

Bits 31-0 Jump Address 

This 32-bit field contains the address of the 
next instruction to fetch when a jump is taken. 
Once the SYM53C876 fetches the instruction 
from the address pointed to by these 32 bits, 
this address is incremented by 4, loaded into 
the DSP register and becomes the current 
instruction pointer. 


Memory Move Instructions 

For Memory Move instructions, bits 5 and 4 
(SIOM and DIOM) in the DMODE register 
determine whether the source or destination 
addresses reside in memory or I/O space. By set¬ 
ting these bits appropriately, data may be moved 
within memory space, within I/O space, or 
between the two address spaces. 

The Memory Move instruction is used to copy the 
specified number of bytes from the source address 
to the destination address. 

Allowing the SYM53C876 to perform memory 
moves frees the system processor for other tasks 
and moves data at higher speeds than available 
from current DMA controllers. Up to 16 MB may 
be transferred with one instruction. There are two 
restrictions: 

1. Both the source and destination addresses 
must start with the same address alignment 
(A(l-O) must be the same). If source and 
destination are not aligned, then an illegal 
instruction interrupt occurs. For the PCI 
Cache Line Size register setting to take effect, 
the source and destination must be the same 
distance firom a cache line boundary. 

2. Indirect addresses are not allowed. A burst of 
data is fetched from the source address, put 
into the DMA FIFO and then written out to 
the destination address. The move continues 
until the byte count decrements to zero, then 
another SCRIPT is fetched from system 
memory. 

The DSPS and DSA registers are additional hold¬ 
ing registers used during the Memory Move; how¬ 
ever, the contents of the DSA register are 
preserved. 

Bits 31-39 Instruction Type—^Memory Move 
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SCSI SCRIPTS Instruction Set 

Memory Move Instructions 


Bits 28-25 Reserved 

These bits are reserved and must be zero. If 
any of these bits is set, an illegal instruction 
interrupt occurs. 

Bit 24 No Flush 

Note: This bit has no effect unless the Pre-fetch 
Enable bit in the DCNTL register is set. 
For information on SCRIPTS instruction 
prefetching, see Chapter 2. 

When this bit is set, the SYM53C876 performs a 
Memory Move without flushing the prefetch unit. 
When this bit is clear, the Memory Move instruc¬ 
tion automatically flushes the prefetch unit. Use 
the No Flush option if the source and destination 
are not within four instructions of the current 
Memory Move instruction. 

Bits 23-0 Transfer Count 

The number of bytes to transfer is stored in the 
lower 24 bits of the first instruction word. 


ory, first move the byte to an intermediate 
SYM53C876 register (for example, a SCRATCH 
register), and then to the SFBR. 

The same address alignment restrictions apply to 
register access operations as to normal memory-to- 
memory transfers. 


Second Dword 

Bits 31-0 DSPS Register 

These bits contain the source address of the 
Memory Move. 

Third Dword 

Bits 31-0 TEMP Register 

These bits contain the destination address for 
the Memory Move. 


Read/Write System Memory from a Script 

By using the Memory Move instruction, single or 
multiple register values are transferred to or from 
system memory. 

Because the SYM53C876 responds to addresses as 
defined in the Base FO or Base Memory registers, 
it can be accessed during a Memory Move opera¬ 
tion if the source or destination address decodes to 
within the chip’s register space. If this occurs, the 
register indicated by the lower seven bits of the 
address is taken as the data source or destination. 
In this way, register values are saved to system 
memory and later restored, and SCRIPTS can 
make decisions based on data values in system 
memory. 

The SFBR is not writable via the CPU, and there¬ 
fore not by a Memory Move. However, it can be 
loaded via SCRIPTS Read/Write operations. To 
load the SFBR with a byte stored in system mem- 
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<— DCMD Register 
31 30 29 28 27 


DBC Register 


26 25 24l23^22^^M^^9^^^^^15 14 13 9^ V 


•—No Flush ▼ 

I— 0 (Reserved) Memory Move byte counter 

I— 0 (Reserved) 

^ 0 (Reserved) 

^ 0 (Reserved) 

— 0 - Instruction Type - Memory Move 
— 1 - Instmction Type - Memory Move 
1 - Instruction Type - Memory Move 


DSPS Register 

31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 


iiSiiiiiilSR 


TEMP Register 

31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 



Figure 5-6: Memory Move Instructions 
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SCSI SCRIPTS Instruction Set 

Load and Store Instructions 


Load and Store 
Instructions 

The Load and Store instruction provides a more 
efficient way to move data ffom/to memory to/ 
from an internal register in the chip without using 
the normal memory move instruction. 

The load and store instructions are represented by 
two-dword op codes. The first dword contains the 
DCMD and DBG register values. The second 
dword contains the DSPS value. This is either the 
actual memory location of where to load or store, 
or the offset from the DSA, depending on the 
value of Bit 28 (DSA Relative). 

A maximum of 4 bytes may be moved with these 
instructions. The register address and memory 
address must have the same byte alignment, and 
the count set such that it does not cross dword 
boundaries. The memory address may not map 
back to the chip, excluding RAM and ROM. If it 
does, a PCI read/write cycle occurs (the data does 
not actually transfer to/from the chip), and the 
chip issues an interrupt (Illegal Instruction 
Detected) immediately following. 


Bits A1, AO 

Number of bytes allowed to load/store 

00 

One, two, three or four 

01 

One, two, or three 

10 

One or two 

11 

One 


The SIOM and DIOM bits in the DMODE regis¬ 
ter determine whether the destination or source 
address of the instruction is in Memory space or 
I/O space, as illustrated in the following table. The 
Load/Store utilizes the PCI commands for I/O 
READ and I/O WRITE to access the I/O space. 

Table 5-2; 


First Dword 

Bit 31-29 Instruction Type 

These bits should be 111, indicating the Load 
and Store instruction. 

Bit 28 DSA Relative 

When this bit is clear, the value in the DSPS is 
the actual 32-bit memory address to perform the 
load/store to/from. When this bit is set, the chip 
determines the memory address to perform the 
load/store to/from by adding the 24-bit signed 
offset value in the DSPS to the DSA. 

Bits 27-26 Reserved 

Bit 25 No Flush (Store instruction only) 

Note: This bit has no effect unless the Pre-fetch 

Enable bit in the DCNTL register is set. For 
information on SCRIPTS instruction 
prefetching, see Chapter 2. 

When this bit is set, the SYM53C876 performs a 
Store without flushing the prefetch unit. When 
this bit is clear, the Store instruction automati¬ 
cally flushes the prefetch unit. Use No Flush if 
the source and destination are not within four 
instructions of the current Store instruction. 
This bit is has no effect on the Load instruction. 

Bit 24 Load/Store 

When this bit is set, the instruction is a Load. 
When cleared, it is a Store. 

Bit 23 Reserved 

Bits 22-16 Register Address 

A6-A0 select the register to load/store to/from 
within the SYM53C876. 

Bits 15-3 Reserved 

Bits 2-0 Byte Count 

This value is the number of bytes to load/store. 


Bit Source Destination 

SIOM (Load) memory register 

DIOM (Store) register memory 


SYM53C876 Data Manual 


5-23 



SCSI SCRIPTS Instruction Set 

Load and Store Instructions 


PRELIMINARY 


Second Dword 

Bits 31-0 Memory/IO Address / DSA Offset 

This is the actual memory location of where to 
load or store, or the offset from the DSA register 
value. 


Byte Count 
(Number of bytes 
to load/store) 



1 Instruction Type - Load and Store 


DSPS Register • Memory/ I/O Address/DSA Offset 


31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 



Figure 5-7: Load and Store Instruction Format 


5-24 


SYM53C8876 Data Manual 



PRELIMINARY 


Electrical Characteristics 

DC Characteristics 


Chapter 6 

Electrical Characteristics 


DC Characteristics 


Table 6-1: Absolute Maximum Stress Ratings 


Symboi 

Parameter 

Min 

Max 

Unit 

Test Conditions 

Tstg 

Storage temperature 

-55 

150 

°C 

- 

Vdd 

Supply voltage 

-0.5 

7.0 

V 

- 

Vest 

Input Voltage 

Vss-0.5 

Vdd 0-5 

V 

- 

Ilp* 

Latch-up current 

± 150 

- 

mA 

- 

ESD*’^ 

Electrostatic discharge 

- 

2K 

V 

MII^STD 883C, 
Method 3015.7 


Stresses beyond those listed above may cause permanent damage to the device. These are stress ratings only;functional operation of 
the device at these or any other conditions beyond those indicated in the Operating Conditions section of the manual is not implied 

*-2V<Vpijq<8V 

** SCSI pins only 


Table 6-2: Operating Conditions 


Symboi 

Parameter 

IBI 

Max 

Unit 

Test Conditions 

Vdd 

Supply voltage 

4.75 

5.25 

V 

- 

Idd 

Supply current (dynamic) 

- 

150 

mA 

- 


Supply current (static) 

- 

1 

mA 

- 

Ta 

Operating free air 

0 

70 


- 

®JA 

Thermal resistance (junc¬ 
tion to ambient air) 

- 

50 

°c/w 

- 


Conditions that exceed the operating limits may cause the device to function incorrectly 
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Table 6-3: SCSI Signals - SD(15-0)/, SDP(l-O)/, SREQ/ SACK/ 


Symbol 

Parameter 

Min 

Max 

Unit 

Test Conditions 

ViH 

Input high voltage 

2.0 

Vdd 

V 

- 

ViL 

Input low voltage 

Vss-0.5 

0.8 

V 

- 

VoH* 

Output high voltage 

2.5 

3.5 

V 

2.5 mA 

VoL 

Output low voltage 

Vss 

0.5 

V 

48 mA 

Iqz 

Tristate leakage 

-10 

10 

pA 

- 


*TohrANT active negation enabled 



Table 6-4: SCSI Signals 

- SMSG, SI_0/, SC_D/, SATN/, SBSY/, 

, SSEU, SRST/ 

Symbol 

Parameter 

Min 

Max 

Unit Test Conditions 

ViH 

Input high voltage 

2.0 

Vdd 0.5 

V 

ViL 

Input low voltage 

Vss-0.5 

0.8 

V 

VoL 

Output low voltage 

Vss 

0.5 

V 48 mA 

Iqz 

Tristate leakage 

-10 

10 

pA 


(SRST/ only) 

-500 

-50 



Table 6-5: Input Signals - 

CLK, SCLK, 

GNT/, IDSEL, RST/, TESTIN, DIFFSENS 

Symbol 

Parameter 

Min 

Max 

Unit Test Conditions 

ViH 

Input high voltage 

2.0 

Vdd + 0.5 

V 

ViL 

Input low voltage 

Vss-0.5 

0.8 

V 

IlN 

Input leakage 

-10 

10 

pA 

Note: SCLK has a 100 pA puU-up that is enabled when TESTIN is low. GNT! and IDSEL have 25 pA pull-ups that are enabled 


when TESTIN is low. TESTIN has a 100 piA pull-up that is always enabled. 
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Electrical Characteristics 

DC Characteristics 


Table 6-6: Capacitance 


Symbol 

Parameter 

Min 

Max 

Unit 

Test Conditions 

Cl 

Input capacitance of 
input pads 

- 

7 

pF 

- 

Cio 

Input capacitance of I/O 
pads 

- 

10 

pF 

- 


Table 6-7: 

Output Signal - 

INTA/, INTB/, REQ/ 



Symbol 

Parameter 

Min 

Max 

Unit 

Test Conditions 

Yqh 

Output high voltage 

2.4 

Ydd 

V 

-16 mA 

VoL 

Output low voltage 

Vss 

0.4 

V 

16 mA 

Iqz 

Tristate leakage 

-10 

10 

\iA 

- 


Note: REQ/, INTAI, and INTBI have 100 puU-ups that are enabled when TESTIN is low. INTA! and INTB! can be enabled 
with a register bit as an open drain output with an internal 100 fiA pull-up. 


Table 6-8: Output Signals - SDIR(15-0), SDIRPO/1, BSYDIR, SELDIR, RSTDIR,TGS, IGS, 2VlAS/(l-0), 

MCE/, MOE/_TESTOUT, MWE/ 


Symbol 

Parameter 

Min 

Max 

Unit 

Test Conditions 

Vqh 

Output high voltage 

2.4 

Vdd 

V 

-4 mA 

VoL 

Output low voltage 

Vss 

0.4 

V 

4 mA 

Iqz 

Tristate leakage 

-10 

10 

jiA 

- 

Note: Each of these output signals have a 

100 fxA pull-up that is enabled when TESTIN is low. 





Table 6-9: Output Signal 

-SERRI 



Symbol 

Parameter 

Min 

Max 

Unit 

Test Conditions 

VoL 

Output low voltage 

Vss 

0.4 

V 

16 mA 

Iqz 

Tristate leakage 

-10 

10 

pA 

- 


Note: SERRI has a 25 nA pull-up that is enabled when TESTIN is low. 
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Table 6-10: Bidirectional Signals - AD(31-0), C_BE/(3-0), FRAME/, IRDY/,TRDY/, DEVSEL/, STOP/, 

PERR/,PAR 


Symboi 

Parameter 

Min 

Max 

Unit 

Test Conditions 

ViH 

Input high voltage 

2.0 

Vdd 0.5 

V 

- 

ViL 

Input low voltage 

Vss-0.5 

0.8 

V 

- 

Vqh 

Output high voltage 

2.4 

Vdd 

V 

16 mA 

VoL 

Output low voltage 

Vss 

0.4 

V 

16mA 

Iqz 

Tristate leakage 

-10 

10 

pA 

- 

Note: All the signals in this table have 25 pA pull-ups that are enabled when TESTIN is low 



Table 6-11: Bidirectional Signals - 

GPIOO_FETCH/, 

GPI01_2VIASTER/, 

GPI02, 

GPI03, GPI04 

Symbol 

Parameter 

Min 

Max 

Unit 

Test Conditions 

ViH 

Input high voltage 

2.0 

Vdd + 0.5 

V 

- 

ViL 

Input low voltage 

Vss-0.5 

0.8 

V 

- 

VOH 

Output high voltage 

2.4 

Vdd 

V 

-16 mA 

VoL 

Output low voltage 

Vss 

0.4 

V 

16 mA 

Iqz 

Tristate leakage 

-10 

10 

pA 

- 


Note: All the signals in this table have 25 flA pull-ups that are enabled when TESTIN is low 
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Electrical Characteristics 

DC Characteristics 


Table 6-12: Bidirectional Signals - MAD(7-0) 


Symbol 

Parameter 

Min 

Max 

Unit 

Test Conditions 

ViH 

Input high voltage 

2.0 

Vdd 0.5 

V 

- 

ViH 

Input high voltage - 
external memory pull- 
downs 

3.85 

Vdd + 0.5 

V 


ViL 

Input low voltage 

Vss-0.5 

0.8 

V 

- 

ViL 

Input low voltage - exter¬ 
nal memory pull-downs 

Vss ■ 0-5 

1.35 

V 

- 

VOH 

Output high voltage 

2.4 

Vdd 

V 

-4 mA 

VoL 

Output low voltage 

Vss 

0.4 

V 

4 mA 

Iqz 

Tristate leakage 

-10 

10 

pA 

- 

Note: All the signals in this table have 100 fiA pull-ups that are enabled when TESTIN is low 




Table 6- 

•13: Input Signals - 

-TDI,TMS,TCK 



Symbol 

Parameter 

Min 

Max 

Unit 

Test Conditions 

ViH 

Input high voltage 

3.85 

Vdd 0.5 

V 

- 

ViL 

Input low voltage 

Vss-0.5 

1.35 

V 

- 

^IN 

Input leakage 

-800 

-200 

pA 

- 


Table 6-14: Output Signal —TDO 


Symbol 

Parameters 

Min 

Max 

Units 

Test Conditions 

Vqh 

Output high voltage 

Vdd - 0.5 

Vdd 

V 

-4 mA 

VoL 

Output low voltage 

Vss 

0.5 

V 

4 mA 

^OZ 

Tristate leakage 

-10 

10 

pA 

- 
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PREUMINARY 


3.3 Volt PCI DC Characteristics 

These characteristics apply whenever a VDD source of 3.3 volts is supplied to the VDD-I pins of the 
SYM53C876. 


Table 6-15: 

Bidirectional Signals— 

-AD(31-0), C_BE(3-0)/, FRAME/, IRDY/,TRDY/, 
PERR/, PAR 

DEVSEli, STOP/, 

Symbol 

Parameter 

Min 

Max 

Units 

Test Conditions 

ViH 

Input high voltage 


0.5 

V 

- 

ViL 

Input low voltage 

-0.5 

0-3 Vdd 

V 

- 

Vqh 

Output high voltage 

0.9 Vdd 

- 

V 

Ioh”" 0.5 mA 

Vql 

Output low voltage 

- 

0-1 Vdd 

V 

Iol= 1-5 mA 

Iqz 

Tristate leakage 

-10 

10 

pA 

- 


Table 6-16: 

Input Signals—CLK, 

GNT/, IDSEL, 

RST/ 


Symbol 

Parameter 

Min 

Max 

Units 

Test Conditions 

ViH 

Input high voltage 

0-5V£)£) 

Vdd 0-5 

V 

- 

ViL 

Input low voltage 

-0.5 

0-3 Vdd 

V 

- 

IlN 

Input leakage 

-10 

10 

pA 

- 

Table 6-17: Output Signals—INTA/, INTB, REQ/ 

Symbol 

Parameter 

Min 

Max 

Units 

Test Conditions 

Vqh 

Output high voltage 

0.9Vdd 

- 

V 

Ioh~" 0.5 mA 

VoL 

Output low voltage 

- 

0.1 Vdd 

V 

Iol= 1«5 mA 

Iqz 

Tristate leakage 

-10 

10 

pA 

- 
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Table 6-18: Output Signal—SERR/ 


Symbol 

Parameter 

Min 

Max 

Units 

Test Conditions 

Vql 

Output low voltage 

- 

0*1 Vdd 

V 

Iol= 1-5 mA 

Iqz 

Tristate leakage 

-10 

10 

|iA 

- 


SYM53C876 Data Manual 


6-7 





Eiectricai Characteristics 

TolerANT Technology Eiectricai Characteristics 


PREUMINARY 


TolerANT Technology Electrical Characteristics 


Table 6-19: TolerANT Technology Electrical Characteristics 


Symbol 

Parameter 

Min 

Max 

Units 

Test Conditions 


Output high voltage 

2.5 

3.5 

V 

Iqh = 2.5 mA 

VoL 

Output low voltage 

0.1 

0.5 

V 

Iql == 48 mA 

ViH 

Input high voltage 

2.0 

7.0 

V 

- 

ViL 

Input low voltage 

-0.5 

0.8 

V 

Referenced toVss 

ViK 

Input clamp voltage 

-0.66 

-0.77 

V 

Vdd = 4.75i 

Ij = -20 mA 

Vth 

Threshold, high to low 

1.1 

1.3 

V 

- 

Vtl 

Threshold, low to high 

1.5 

1.7 

V 

- 

Vth- 

Vtl 

Hysteresis 

200 

400 

mV 

- 


Output high current 

2.5 

24 

mA 

Voh = 2.5V 

Iql 

Output low current 

100 

200 

mA 

Vol = 0.5V 

T 1 
^OSH 

Short-circuit output 
high current 


625 

mA 

Output driving low, 
pin shorted toVoD 
supply^ 

Iqsl 

Short-circuit output low 
current 


95 

mA 

Output driving 
high, pin shorted to 
Vss supply 

Ilh 

Input high leakage 

" 

10 

jiA 

-0.5 <Vdd< 5.25 
VpiN = 2.7V 

III 

Input low leakage 

• 

-10 

pA 

-0.5 <Vdd < 5.25 
VpiN = 0.5V 

Ri 

Input resistance 

20 

- 

MQ. 

SCSI pins^ 

Cp 

Capacitance per pin 

- 

10 

pF 

PQFP 


Rise time, 10% to 90% 

9.7 

18.5 

ns 

Figure 7-1 

tp 

Fall time, 90% to 10% 

5.2 

14.7 

ns 

Figure 7-1 

ciVn/dt 

Slew rate, low to high 

0.15 

0.49 

V/ns 

Figure 7-1 

dWiJdt 

Slew rate, high to low 

0.19 

0.67 

V/ns 

Figure 7-1 

ESD 

Electrostatic discharge 

2 

- 

KV 

MIL-STD-883C; 

3015-7 


Note: These values are guaranteed by periodic characterization; they are not 100% tested on every device. 


^Active negation outputs only:Dataj Parity, SREQ/, SACK/ 

^Single pin only; irreversible damage may occur if sustained for one second 
^SCSI RESET pin has 10 kQ pull-up resistor 
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Table 6-19: TolerANT Technology Electrical Characteristics (Continued) 


Symbol Parameter 

Min 

Max 

Units 

Test Conditions 

Latch-up 

150 

- 

mA 

- 

Filter delay 

20 

30 

ns 

Figure 7-2 

Extended filter delay 

40 

60 

ns 

Figure 7-2 


Note: These values are guaranteed by periodic characterization; th^ are not 100% tested on every device. 
^ Active negation outputs only: Data, Parity, SREQI, SACK! 

^Single pin only; irreversible damage may occur if sustained for one second 
^SCSI RESET pin has 10 kQ pull-up resistor 


REQ/or ACK/Input 



is the input filtering period 


Figure 6-1: Rise and Fall Time Test Conditions 


47 Q 



Figure 6-2: SCSI Input Filtering 
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-4 0 4 8 12 16 

Input Voltage (Volts) 

Figure 6-4: Input Current as a Function of Input Voltage 
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0 - 
-200 _ 

-400 _ 

-600 

-800 - 

012345 012345 

Output Voltage (Volts) Output Voltage (Volts) 

Figure 6-5: Output Current as a Function of Output Voltage 
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AC Characteristics 

The AC characteristics described in this section apply over the entire range of operating conditions (refer 
to the DC Characteristics section). Chip timings are based on simulation at worst case voltage, tempera¬ 
ture, and processing. 

This part of the chapter contains AC Characteristics for the PCI Interface, and the SCSI Interface. 


Table 6-20: Clock Timing 


Symbol 

Parameter 

Min 

Max 

Units 


Bus clock cycle time 

30 

DC 

ns 


SCSI clock cycle time (SCLK)* 

15 

60 

ns 


CLK low time"*^* 

12 

- 

ns 


SCLK low time*’*' 

6 

33 

ns 

h 

CLK high time’*^'*^ 

12 

- 

ns 


SCLK high time** 

6 

33 

ns 

t4 

CLK slew rate 

1 

- 

V/ns 


SCLK slew rate 

1 

- 

ns 


*This parameter must be met to insure SCSI timings are within specification 
**Duty cycle not to exceed 60140 


CLK/SCLK 



--► 

\ _ / 

-► 



Figure 6-6: Clock Timing 
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AC Characteristics 


Table 6-21: Reset Input 


Symboi 

Parameter 

Min 

Max 

Units 


Reset pulse width 

30 

DC 

ns 

^2 

Reset deasserted setup to CLK high 

12 

- 

ns 

^3 

MAD setup time to CLK high (for configuring the MAD 
bus only) 

12 

- 

ns 


MAD hold time from CLK high (for configuring the 

MAD bus only) 

1 

- 

V/ns 
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Table 6-22: Interrupt Output 


Symbol Parameter 


Min 


Max 


Units 
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AC Characteristics 


PCI Interface Timings 

This section includes timing diagrams fro access to three groups of external memory configurations. The 
first group applies to systems with memory size of 128 KB and above; one byte read or write cycle, and 
fast or normal ROMs. The second group applies to system with memory size of 128 KB and above, one- 
byte read or write cycles, and slow ROMs. The third group applies to systems with memory size of 64 KB 
or less, one-byte read or write cycles, and normal or fast ROM. 

Note: Multiple bjrte access to the external memory bus increase the read or write cycle by 11 clocks for 
each additional byte. 

Timing diagrams included in this section 

■ PCI configuration register read 

■ PCI configuration register write 

■ Target Read, without external memory 

■ Target Write, without external memory 

■ Target Read, with external memory 

■ Target Write, with external memory 

■ Op Code Fetch, non-Burst 

■ Op Code Ftech, Burst 

■ Back-to-Back Read 

■ Back-to-Back Write 

■ Read Cycle, normal/fast ROM, single-byte access 

■ Write Cycle, normal/fast ROM, single-byte access 

■ Read Cycle, normal/fast ROM, multiple-byte access 

■ Write Cycle, normal/fast ROM, multiple-byte access 

■ Read Cycle, slow memory 

■ Write Cycle, slow memory 

■ Read Cycle, 16 KB ROM 

■ Write Cycle, 16 KB ROM 
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Table 6-23: Configuration Register Read 


Symbol 

Parameter 


Max 

Unit 

h 

Shared signal input setup time 

7 


ns 

h 

Shared signal input hold time 

0 

- 

ns 


CLK to shared signal output valid 

- 

11 

ns 
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CLK 

(Driven by System) 


FRAME/ 
(Driven by System) 

AD/ 

(Driven by Master-Addr; 
SYM53C876-Data) 

C_BE/ 

(Driven by Master) 
PAR 

(Driven by Master-Addr; 
SYM53C876-Data) 

IRDY/ 

(Driven by Master) 
TRDY/ 

(Driven by SYM53C876) 
STOP/ 

(Driven by SYM53C876) 



DEVSEL/ 
(Driven by SYM53C876) 

IDSEL 

(Driven by Master) 



Figure 6>9: Configuradon Register Read 
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Table 6-24: Configuration Register Write 


Symboi 

Parameter 

Min 

Max 

Unit 


Shared signal input setup time 

7 

- 

ns 

^2 

Shared signal input hold time 

0 

- 

ns 

^3 

CLK to shared signal output valid 

- 

11 

ns 
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Table 6-25: Target Read, not from external memory 


Symbol 

Parameter 

Min 

Max 

Unit 


Shared signal input setup time 

7 

- 

ns 

t2 

Shared signal input hold time 

0 

- 

ns 

^3 

CLK to shared signal output valid 

- 

11 

ns 
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Table 6 - 26 : Target Write, not from external memory 


Symbol 

Parameter 

Min 

Max 

Unit 


Shared signal input setup time 

7 

- 

ns 

h 

Shared signal input hold time 

0 

- 

ns 

h 

CLK to shared signal output valid 

- 

11 

ns 
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Table 6-27: Target Read, from external memory 


Symbol 

Parameter 

Min 

Max 

Unit 


Shared signal input setup time 

7 

- 

ns 


Shared signal input hold time 

0 

- 

ns 

^3 

CLK to shared signal output valid 

- 

11 

ns 

^4 

Side signal input setup time 

10 

- 

ns 

til 

Address setup to MAS/ high 

25 

- 

ns 

tl2 

Address hold from MAS/ high 

15 

- 

ns 

tl3 

MAS/ pulse width 

25 

- 

ns 

tl4 

MCE/ low to data clocked in 

160 

- 

ns 

tl5 

Address valid to data clocked in 

205 

- 

ns 

tl6 

MOE/ low to data clocked in 

100 

- 

ns 

tl7 

Data hold from address, MOE/, MCE/ change 

0 

- 

ns 

tl8 

Address out from MOE/, MCE/ high 

50 

- 

ns 

tl9 

Data setup to CLK high 

5 

- 

ns 
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(Driven by Msier-Addr 
SYMS3(M4)A) 



TROY 

(DiMnliySyie3(»76) 

STOP/ 

(Driven by SYMS3C876) 

DEVSEU 
(Driven by SYMS3C876) 


MAO 

(A(idrdriveflliySYM53(»76; 
Data driven by menioiy) 


(»>K)2 

(Driven by SYMS3(»76) 


MAS1/ 

(Driven by SYM53(»76) 
MASO/ 

(Driven by SYM53C876) 
MCE/ 

(Driven by SYM53C876) 
Ml 

(Driven by SYM53C876) 
MW& 

(Driven by SYM53C876) 
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Table 6-28; Target Write, from external memory 


Symbol 

Parameter 

Min 

Max 

Unit 


Shared signal input setup time 

7 

- 

ns 


Shared signal input hold time 

0 

- 

ns 

^3 

CLK to shared signal output valid 

- 

11 

ns 

til 

Address setup to MAS/ high 

25 

- 

ns 

tl2 

Address hold from MAS/ high 

15 

- 

ns 

tl3 

MAS/ pulse width 

25 

- 

ns 

t20 

Data setup to MWE/ low 

30 

- 

ns 

t21 

Data hold from MWE/ high 

20 

- 

ns 

t22 

MWE/ pulse width 

100 

- 

ns 

t23 

Address setup to MWE/ low 

75 

- 

ns 

t24 

MCE/ low to MWE/ high 

120 

- 

ns 

t25 

MCE/low to MWE/low 

25 

- 

ns 

t26 

MWE/ high to MCE/ high 

25 

- 

ns 
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Table 6-29: Op Code Fetch, non-Burst 


Symbol 

Parameter 

Min 

Max 

Unit 


Shared signal input setup time 

7 


ns 

^2 

Shared signal input hold time 

0 

- 

ns 


CLK to shared signal output valid 

- 

11 

ns 

t4 

Side signal input setup time 

10 

- 

ns 

^5 

Side signal input hold time 

0 

- 

ns 

*6 

CLK to side signal output valid 

- 

12 

ns 

^7 

CLK high to FETCH/ low 

- 

20 

ns 

^8 

CLK high to FETCH/ high 

- 

20 

ns 


CLK high to MASTER/ low 

- 

20 

ns 

^10 

CLK high to MASTER/ high 

- 

20 

ns 
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Figure 6-15: Op Code Fetch, non-Burst 
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Table 6-30: Op Code Fetch, Burst 


Symboi 

Parameter 

Min 

Max 

Unit 


Shared signal input setup time 

7 

- 

ns 


Shared signal input hold time 

0 

- 

ns 

^3 

CLK to shared signal output valid 

- 

11 

ns 

^4 

Side signal input setup time 

10 

- 

ns 

^5 

Side signal input hold time 

0 

- 

ns 

^6 

CLK to side signal output valid 

- 

12 

ns 

^7 

CLK high to FETCH/ low 

- 

20 

ns 


CLK high to FETCH/ high 

- 

20 

ns 


CLK high to MASTER/ low 

- 

20 

ns 

tio 

CLK high to MASTER/ high 

- 

20 

ns 
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Figure 6-16: Op Code Fetch, Burst 
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Table 6-31: Back to Back Read 


Symbol 

Parameter 

Min 

Max 

Unit 


Shared signal input setup time 

7 

- 

ns 


Shared signal input hold time 

0 

- 

ns 

^3 

CLK to shared signal output valid 

- 

11 

ns 


Side signal input setup time 

10 

- 

ns 

t5 

Side signal input hold time 

0 

- 

ns 

^6 

CLK to side signal output valid 

- 

12 

ns 

^9 

CLK high to MASTER/ low 

- 

20 

ns 

tio 

CLK high to MASTER/ high 

> 

20 

ns 
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CLK 

(Driven by System) 


GPlOO FETCH/ 
(Driven by SYM53C876)* 


GPI01_MASTER/ 
(Driven by SYM53C876) 


RE(3/ 

(Driven by SYM53C876) 


GNT/ 

(Driven by Arbiter) 


FRAME/ 
(Driven by SYM53C876) 


AD/ 
(Driven by 
SYM53C876-A(ldr: 
Target-Data) 


C_BE/ 

(Driven bySYM53C876) 


(Driven by 
SYM53C876-Addr: 
Target-Data) 


IRDY/ 

(Driven by SYM53C876) 


TRDY/ 
(Driven by Target) 


STOP/ 
(Driven by Target) 

devsel; . 

(Driven by Target) 



Figure 6-17: Back to Back Read 
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Table 6-32: Back to Back Write 


Symbol 

Parameter 

Min 

Max 

Unit 


Shared signal input setup time 

7 

- 

ns 

^2 

Shared signal input hold time 

0 

- 

ns 

^3 

CLK to shared signal output valid 

- 

11 

ns 

^4 

Side signal input setup time 

10 

- 

ns 

^5 

Side signal input hold time 

0 

- 

ns 

^6 

CLK to side signal output valid 

- 

12 

ns 

tg 

CLK high to 2V1ASTER/ low 

- 

20 

ns 

^10 

CLK high to MASTER/ high 

- 

20 

ns 
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Table 6-33s Burst Read 


Symbol 

Parameter 

Min 

Max 

Unit 


Shared signal input setup time 

7 

- 

ns 

^2 

Shared signal input hold time 

0 

- 

ns 

^3 

CLX to shared signal output valid 

- 

11 

ns 

U 

Side signal input setup time 

10 

- 

ns 

t5 

Side signal input hold time 

0 

- 

ns 

^6 

CLK to side signal output valid 

- 

12 

ns 


CLK high to MASTER/ low 

- 

20 

ns 

^10 

CLK high to MASTER/ high 

- 

20 

ns 
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CLK 

GPIOO.FETCH/ 
(Driven by SYM53C876) 


GPI01_MASTER/ 
(Driven by SYM53C876) 

RED/ 

(Driven by SYM53C876) 
GNT/ 

(Driven by Arbiter) 
FRAME 

(Driven by SYM53C876) 
AD 

(Driven by SYM53C876-Addr, 
Target-Data) 

C_BE/ 

(Driven by SYM53C876) 
PAR 

(Driven by SYM53C876 for 
Address, by Target for Data 

IRDY/ 

(Driven by SYM53C876) 

TRDY/ 
(Driven by Target) 

STOP/ 
(Driven by Target) 

DEVSEiy 
(Driven by Target) 
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Table 6-34: Burst Write 


Symbol 

Parameter 

Min 

Max 

Unit 

h 

Shared signal input setup time 

7 

- 

ns 

^2 

Shared signal input hold time 

0 

- 

ns 

^3 

CLK to shared signal output valid 

- 

11 

ns 


Side signal input setup time 

10 

- 

ns 

ts 

Side signal input hold time 

0 

- 

ns 

^6 

CLK to side signal output valid 

- 

12 

ns 

^9 

CLK high to MASTER/ low 

- 

20 

ns 

^10 

CLK high to MASTER/ high 

- 

20 

ns 
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Table 6-35: Read Cycle, Normal/Fast Memory ^128 KB), single byte access 


Symbol 

Parameter 

Min 

Max 

Unit 

til 

Address setup to MAS/ high 

25 

- 

ns 

tl2 

Address hold from MAS/ high 

15 

- 

ns 

tl3 

MAS/ pulse width 

25 

- 

ns 

tl4 

MCE/ low to data clocked in 

160 

- 

ns 

tl5 

Address valid to data clocked in 

205 

- 

ns 

tl6 

MOE/ low to data clocked in 

100 

- 

ns 

tl7 

Data hold from address, MOE/, MCE/ change 

0 

- 

ns 

tl8 

Address out from MOE/, MCE/ high 

50 

- 

ns 

tl9 

Data setup to CLK high 

5 

- 

ns 
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Figure 6-21: Read Cycle, Normal/Fast Memory (>128 KB), single byte access 



MAD 

(Addr driven by SYM53C876; 
Data driven by memory) 

MAS1/ 

(Driven by SYM53C876) 


MASO/ 

(Driven by SYM53C876) 


MCE/ 

(Driven by SYM53C876) 


MOE/ 

(Driven by SYM53C876) 
MWE/ 

(Driven by SYM53C876) 
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Table 6-36: Read Cycle, Normal/Fast Memory (>128 KB), single byte access 


Symboi 

Parameter 

Min 

Max 

Unit 


til 

Address setup to MAS/ high 

25 

- 

ns 


tl2 

Address hold from MAS/ high 

15 

- 

ns 


tl3 

MAS/ pulse width 

25 

- 

ns 


t20 

Data setup to MWE/ low 

30 

- 

ns 


t21 

Data hold from MWE/ high 

20 

- 

ns 


t22 

MWE/ pulse width 

100 

- 

ns 


t23 

Address setup to MWE/ low 

75 

- 

ns 


t24 

MCE/ low to MWE/ high 

120 

- 

ns 


t25 

MCE/ low to MWE/ low 

25 

- 

ns 


t26 

MWE/ high to MCE/ high 

25 

- 

ns 
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Figure 6-22: Write Cycle, Normal/Fast Memory (>128 KB), single byte access 
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Figure 6-23: Read Cycle, Normal/Fast Memory (>128 KB), multiple byte access 
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Figure 6-23: Read Cycle, Normal/Fast Memory (^128 KB), multiple byte access (continued) 
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Figure 6-24; Write Cycle, Normal/Fast Memory (>128 KB), multiple byte access 
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Figure 6-24: Write Cycle, Normal/Fast Memory (>128 KB), multiple byte access (continued) 
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Table 6-37: Read Cycle, Slow Memory (>128 KB) 


Symbol 

Parameter 

Min 

Max 

Unit 

til 

Address setup to MAS/ high 

25 

- 

ns 

tl2 

Address hold from MAS/ high 

15 

- 

ns 

tl3 

MAS/ pulse width 

25 

- 

ns 

tl4 

MCE/ low to data clocked in 

160 

- 

ns 

tl5 

Address valid to data clocked in 

205 

- 

ns 

tl6 

MOE/ low to data clocked in 

100 

- 

ns 

tl7 

Data hold from address, MOE/, MCE/ change 

0 

- 

ns 

tie 

Address out from MOE/, MCE/ high 

50 

- 

ns 

tl9 

Data setup to CLK high 

5 

- 

ns 
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Figure 6-25; Read Cycle, Slow Memory (>128 KB) 
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Table 6-38: Write Cycle, Slow Memory (>128 KB) 


Symboi 

Parameter 


Max 

Unit 

til 

Address setup to MAS/ high 

25 


ns 

tl2 

Address hold from MAS/ high 

15 

- 

ns 

tl3 

MAS/ pulse width 

25 

- 

ns 

t20 

Data setup to MWE/ low 

30 

- 

ns 

t21 

Data hold from MWE/ high 

20 

- 

ns 

t22 

MWE/ pulse width 

100 

- 

ns 

t23 

Address setup to MWE/ low 

75 

- 

ns 

t24 

MCE/ low to MWE/ high 

120 

- 

ns 

t25 

MCE/ low to MWE/ low 

25 

- 

ns 

t26 

MWE/ high to MCE/ high 

25 

- 

ns 
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Figure 6-26: Write Cycle, Slow Memory (>128 KB) 
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Table 6-39: Read Cycle, 16 KB ROM 


Symbol 

Parameter 

Min 

Max 

Unit 

til 

Address setup to MAS/ high 

25 

- 

ns 

tl2 

Address hold from MAS/ high 

15 

- 

ns 

tl3 

MAS/ pulse width 

25 

- 

ns 

tl4 

MCE/ low to data clocked in 

160 

- 

ns 

tl5 

Address valid to data clocked in 

205 

- 

ns 

tl6 

MOE/ low to data clocked in 

100 

- 

ns 

tl7 

Data hold from address, MOE/, MCE/ change 

0 

- 

ns 

tl8 

Address out from MOE/, MCE/ high 

50 

- 

ns 

tl9 

Data setup to CLK high 

5 

- 

ns 
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Figure 6-27: Read Cycle, 16 KB ROM 
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Table 6-40: Write Cycle, 16 KB ROM 


Symbol 

Parameter 

Min 

Max 

Unit 

til 

Address setup to MAS/ high 

25 

- 

ns 

tl2 

Address hold from MAS/ high 

15 

- 

ns 

tl3 

MAS/ pulse width 

25 

- 

ns 

t20 

Data setup to MWE/ low 

30 

- 

ns 

t21 

Data hold from MWE/ high 

20 

- 

ns 

t22 

MWE/ pulse width 

100 

- 

ns 

t23 

Address setup to MWE/ low 

75 

- 

ns 

t24 

MCE/ low to MWE/ high 

120 

- 

ns 

t25 

MCE/ low to MWE/low 

25 

- 

ns 

t26 

MWE/ high to MCE/ high 

25 

- 

ns 


6-54 


SYM53C876 Data Manual 


Figure 6-28; Write Cycle, 16 KB ROM 
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SCSI Interface Timings 


Table 6-41: Initiator Asynchronous Send 


Symbol 

Parameter 

Min 

Max 

Units 

ti 

SACK/ asserted from SREQ/ asserted 

5 

« 

ns 

h 

SACK/ deasserted from SREQ/ deasserted 

5 

- 

ns 

^3 

Data setup to SACK/ asserted 

55 

- 

ns 


Data hold from SREQ/ deasserted 

20 

- 

ns 


SREQ/ 


SACK/ 


\ 




n+1 


n+1 


U-H 


SD15-SD0, 
SDP1/. SDPO/ 


Valid n 


Valid n-i-1 


Figure 6-29: Initiator Asynchronous Send 
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Table 6-42: Initiator Asynchronous Receive 


Symboi 

Parameter 

Min 

Max 

Units 


SACK/ asserted from SREQ/ asserted 

5 

- 

ns 

h 

SACK/ deasserted from SREQ/ deasserted 

5 

- 

ns 

^3 

Data setup to SREQ/ asserted 

0 

- 

ns 


Data hold from SACK/ asserted 

0 

- 

ns 


SREQ/ 

SACK/ 

SD15-SD0, 
SDP1/. SDPO/ 


\L_i_J \ 

'' V " / \jl!l 

—*4—*-j 




Valid n+1 


Valid n 


Figure 6-30: Initiator Asynchronous Receive 
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Table 6-43: Target Asynchronous Send 


Symbol 

Parameter 

Min 

Max 

Units 

ti 

SREQ/ deasserted from SACK/ asserted 

5 

- 

ns 

^2 

SREQ/ asserted from SACK/ deasserted 

5 

- 

ns 

^3 

Data setup to SREQ/ asserted 

55 

- 

ns 


Data hold from SACK/ asserted 

20 

- 

ns 



Figure 6-31: Target Asynchronous Send 
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Table 6-44: Target Asynchronous Receive 


Symbol 

Parameter 

Min 

Max 

Units 


SREQ/ deasserted from SACK/ asserted 

5 

- 

ns 

^2 

SREQ/ asserted from SACK/ deasserted 

5 

- 

ns 

^3 

Data setup to SACK/ asserted 

0 

- 

ns 

^4 

Data hold from SREQ/ deasserted 

0 

- 

ns 


SREQ/ 

SACK/ 


n+1 


n+1 


SD15-SD0. 
SDP1/. SDPO/ 


Valid n 


Valid n+1 


Figure 6-32: Target Asynchronous Receive 
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Figure 6-33: Initiator and Target Synchronous Transfers 
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Table 6-45: SCSI-1 transfers (Single-Ended, 5.0 MB/s) 


Symbol 

Parameter 

Min 

Max 

Units 

h 

Send SREQ/ or SACK/ assertion pulse width 

90 

- 

ns 

^2 

Send SREQ/ or SACK/ deassertion pulse width 

90 


ns 


Receive SREQ/ or SACK/ assertion pulse width 

90 

- 

ns 

^2 

Receive SREQ/ or SACK/ deassertion pulse width 

90 

- 

ns 

t3 

Send data setup to SREQ/ or SACK/ asserted 

55 

- 

ns 

t4 

Send data hold from SREQ/ or SACK/ asserted 

100 

- 

ns 


Receive data setup to SREQ/ or SACK/ asserted 

0 

~ 

ns 

t6 

Receive data hold from SREQ/ or SACK/ asserted 

45 

- 

ns 
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Table 6-46: SCSI-2 Fast Transfers (10.0 MB/s (8-bit transfers) or 20.0 MB/s (16-bit transfers), 

40 MHz clock) 


Symbol 

Parameter 

Min 

Max 

Units 


Send SREQ/ or SACK/ assertion pulse width 

35 

- 

ns 

h 

Send SREQ/ or SACK/ deassertion pulse width 

35 

- 

ns 

U 

Receive SREQ/ or SACK/ assertion pulse width 

20 

- 

ns 


Receive SREQ/ or SACK/ deassertion pulse width 

20 

- 

ns 

^3 

Send data setup to SREQ/ or SACK/ asserted 

33 

- 

ns 


Send data hold from SREQ/ or SACK/ asserted 

45 

- 

ns 

h 

Receive data setup to SREQ/ or SACK/ asserted 

0 

- 

ns 

^6 

Receive data hold from SREQ/ or SACK/ asserted 

10 

- 

ns 


Table 6-47: SCSI-2 Fast-20 Single-Ended Transfers (20.0 MB/s (8-bit transfers) or 40.0 MB/s 
(16-bit transfers), 80 MHz clock) with clock doubled internally 


Symbol 

Parameter 

Min 

Max 

Unit 


Send SREQ/ or SACK/ assertion pulse width 

16 

- 

ns 

^2 

Send SREQ/ or SACK/ deassertion pulse width 

16 

- 

ns 

tl 

Receive SREQ/ or SACK/ assertion pulse width 

10 

- 

ns 

h 

Receive SREQ/ or SACK/ deassertion pulse width 

10 

- 

ns 

h 

Send data setup to SREQ/ or SACK/ asserted 

12 

- 

ns 

U 

Send data hold from SREQ/ or SACK/ asserted 

17 

- 

ns 

t5 

Receive data setup to SREQ/ or SACK/ asserted 

0 

- 

ns 

^6 

Receive data hold from SREQ/ or SACK/ asserted 

6 

- 

ns 
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Appendix A 

Register Summary 


Configuration Registers 


Register OOh 

Vendor ID 

Read Only 

VID 

VID 

VID 

VID 

15-12 

11-8 

7-4 

3-0 

Default »> 




1 

0 

0 

0 

Register 02h 




Device ID 




Read Only 




DID 

DID 

DID 

DID 

15-12 

11-8 

7-4 

3-0 

Default »> 




0 

0 

0 

F 


Register 04h 

Command 

ReadlWrite 



SE 

iiiii 

EPER 

RES 

WIE 

RES 

EBM 

EMS 

EIS 

15*9 

8 

7 

6 

5 

4 

3 

2 

1 

0 


Default »> 

0 0 

0 0 0 0 0 

Bits 15-9 

Reserved 

Bits 

SERR/ Enable(SE) 

Bit? 

Reserved 

Bite 

Enable Parity Error Response (EPER) 

Bits 

Reserved 

Bit 4 

Write and Invalidate Enable (WIE) 

Bits 

Reserved 

Bit 2 

Enable Bus Mastering (EBM) 

Bit 1 

Enable Memory Space (EMS) 

BitO 

Enable I/O Space (EIS) 


Register 06h 

Status 

ReadlWrite 


DPE 

SSE 

RMA 

RTA 

RES 

DT 

DPR 

RES 

15 

14 

13 

12 

11 

10-9 

8 

7-0 

Default »> 

0 0 

0 

0 

0 

0 

0 

0 


Bit 15 

Detected Parity Error (DPE) 
(from Slave) 

Bit 14 

Signaled System Error (SSE) 

Bit 13 

Received Master Abort (RMA) 
(from Master) 

Bit 12 

Received Target Abort (RTA) 
(from Master) 

Bit 11 

Reserved 

Bits 10-9 

DEVSEIV Timing (DT) 

Bits 

Data Parity Reported(DPR) 

Bits 7-0 

Reserved 

Register 08h 

Revision ID 

Read Only 


RID 

RID 

RID 

RID 

RID 

RID 

RID 

RID 

7 

6 

5 

4 

3 

2 

1 

0 

Default »> 

0 0 

0 

1 

X 

X 

X 

X 


This field specifies device and revision identifiers. 
In the SYM53C876, the upper nibble is Olh. The 
lower Register 09h 
Class Code 
Read Only 


CC 

CC 

CC 

CC 

CC 

CC 

23-20 

19-16 

15-12 

11-8 

7-4 

3-0 

Default »> 

0 

1 

0 

0 

0 

0 
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Configuration Registers 


PREUMINARY 


Register OCh 
Cacheline Size 
ReadtWrite 


Register 18h 

Base Address Two (Memory) 
Read/Write 


CIS 



CLS 



CLS 

CLS 

7 

Hi 

n 

4 

HI 

n 

1 

0 

Default >» 

0 0 

0 

0 

0 

0 

0 

0 


BAT 

BAT 

1 bat I 

BAT 


BAT 

BAT 

rBAf-i 

31-28 

27-24 


19-16 


11-8 

7-4 


Default »> 

X X 

X 

X 

X 

X 

X 

XXXO 


Register ODh 
Latency Timer 
ReadfWrite 


LT LT 

7 6 

HH 

LT LT 

3 2 

LT LT 

1 0 

Default »> 

0 0 0 0 

0 0 0 0 

Register OEh 

Header Type 

Read Only 

HT 

7-4 

HT 

3-0 

Default »> 

8 

0 

Register OFh 

BIST 

Read Only 

BIST Capable 

7 

Start BIST 

6 

RES 

5-4 

Completion Code 
3-0 


Default »> 


0 0 00 0000 


Register lOh 

Base Address Zero (I/O) 

ReadfWrite 


BAZ 


BAZ 

BAZ 


BAZ 


BAZ 

31-28 

27-24 

23-20 

19-16 

15-12 

11-8 

7-4 

3-0 

Default »> 

X X 

X 

X 

X 

X 

X 

xxxl 


Register 14h 

Base Address One (Memory) 
ReadfWrite 


Register 2Ch 
Subsystem Vendor ID 
Read Only 


SVID 

SVID 

SVID 

SVID 

15-12 

11-8 

7-4 

3-0 


If EEPROM not enabled «<Default»> 

0 0 0 0 


EEPROM value if EEPROM enabled «<Default»> 

X X X X 


Register 2Eh 
Subsystem ID 
Read Only 



SID 

SID 

SID 

15-12 

11-8 

7-4 

3-0 


If EEPROM not enabled «<Default»> 

0 0 0 0 


EEPROM value if EEPROM enabled «<Default»> 

X X X X 


Register 30h 

Expansion ROM Base Address 
ReadfWrite 


ERBA 

ERBA 

ERBA 

ERBA 

ERBA 

ERBA 

ERBA 

ERBA 

31-28 

27-24 

23-20 

19-16 

15-12 

11-8 

7-4 

3-0 

Default»> 

0 0 

0 

0 

0 

0 

0 

0 


Register 3Ch 
Interrupt line 
ReadfWrite 


IL 

IL 

IL 

IL 

IL 

IL 

IL 

IL 

7 

6 

5 

4 

3 

2 

1 

0 

Default »> 

0 0 

0 

0 

0 

0 

0 

0 


BAO 

BAO 

BAO 

BAO 

BAO 

BAO 

BAO 

BAO 

31-28 

27-24 

23-20 

19-16 

15-12 

11-8 

7-4 

3-0 

Default »> 

X X 

X 

X 

X 

X 

X 

XXXO 
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Register Summary 

SCSI Registers 

Register 3Dh 

Register Olh 


Interrupt Pin 

SCSI Control One (SCNTLl) 


Read Only 

ReadlWrite 



SCSI Function A «<Oefault »> 
0 0 0 


IP 

2 

IP 

1 

IP 

0 


0 

0 

1 


0 

»> 

0 

1 


0 

1 

0 



Register 3Eh 
Min_Gnt 
Read Only 

MG MG 
7 


Default »> 

0 0 

Register 3Fh 
Max_Lat 
Read Only 


MG MG MG 

2 1 0 


SCSI Registers 


Register OOh 

SCSI Control Zero (SCNTLO) 
Read! Write 

ARBO START WATN EPC 

6 5 4 3 


Default »> 

110 0 0 


ARBI 

ARBO 

7 

6 


AAP TRG 

1 0 


EXC 

7 


Default »> 

0 0 


AESP 

lARB 

2 

1 


EXC (Extra Clock Cycle of Data Setup) 

ADB (Assert SCSI Data Bus) 

DHP (Disable Halt on Parity Error or ATN) (Target 
Only) 

CON (Connected) 

RST (Assert SCSI RST/ Signal) 

AESP (Assert Even SCSI Parity (force bad parity)) 
lARB (Immediate Arbitration) 

SST (Start SCSI Transfer) 


CAUTION: 


Register 02h 

SCSI Control Two (SCNTL2) 
Read! Write 


ML ML 

ML 

ML 

ML 

ML 

ML 

ML 

7 6 

5 

4 

3 

2 

1 

0 

Default »> 

0 1 

0 

0 

0 

0 

0 

0 


SDU 

CHM 

SLPMD 

SLPH¬ 

BEN 

WSS 

VUEO 

VUEl 

WSR 

7 

6 

5 

4 

3 

2 

1 

0 

Default »> 

0 0 

0 

0 

0 

0 

X 

0 


SDU (SCSI Disconnect Unexpected) 

CHM (Chained Mode) 

SLPMD (SLPAR Mode Bit) 

SLPHBEN (SLPAR High Byte Enable) 
WSS (Wide SCSI Send) 

VUEO (Vendor Unique Enhancement bit 0) 
VUEl (Vendor Unique Enhancement bit 1) 
WSR (Wide SCSI Receive) 


Register 03h 

SCSI Control Three (SCNTL3) 
ReadlWrite 


SCF2 SCF1 

7 I 6 5 

Default »> 


CCF2 CCF1 CCFO 

2 1 0 


Bit 7 ARBI (Arbitration Mode bit 1) 

Bit 6 ARBO (Arbitration Mode bit 0) 

Bit 5 START (Start Sequence) 

Bit 4 WAT>J (Selea with SATN/ on a Start Sequence) 
Bit 3 EPC (Enable Parity Checking) 

Bit 2 Reserved 

Bit 1 AAP (Assert SATN/ on Parity Error) 

Bit 0 TRG (Target Mode) 


00000000 

Bit 7 USE (Ultra SCSI Enable) 

Bits 6-4 SCF2-0 (Synchronous Clock 
Conversion Factor) 

Bit 3 EWS (Enable Wide SCSI) 

Bits 2-0 CCF2-0 (Clock Conversion Factor) 
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Register 04h 

SCSI Chip ID (SCID) 

ReadlWrite 


Register 08h 

SCSI First Byte Received (SFBR) 

ReadlWrite 



RRE 

6 

m 

RES 

4 

ENC3 

3 

ENC2 

2 

ENC1 

1 

ENCO 

0 

Default »> 

X 0 

0 

X 

0 

0 

0 

0 

Bit 7 

Bit 6 

Bits 

Bit 4 

Bits 3-0 

Reserved 

RRE (Enable Response to 

Reselection) 

SRE (Enable Response to Selection) 
Reserved 

Encoded Chip SCSI ID, bits 3-0 




Register 05h 

SCSI Transfer (SXFER) 

ReadlWrite 

TP2 

TP1 

TPO 

M04 

M03 

M02 

M01 

MOO 

7 

6 

5 

4 

3 

2 

1 

0 

Default >» 







0 

0 

0 

X 

0 

0 

0 

0 

Bits 7-5 

TP2-0 (SCSI Synchronous Transfer Period) 


Bits 4-0 

MO4-MO0 (Max SCSI Synchronous Of&et) 


Register 06h 







SCSI Destination ID (SDID) 




ReadlWrite 







■a 

■ 



ENC3 

ENC2 

ENC1 

ENCO 

n 


1 


3 

2 

1 

0 

Default »> 







X 

X 

X 

X 

0 

0 

0 

0 

Bits 7-4 

Reserved 






Bits 3-0 

Encoded Destination SCSI ID 





Register 07h 







General Purpose (GPREG) 





ReadlWrite 










6PI04 

GPI03 

GPI02 

GPI01 

GPlOO 


6 

5 

4 

3 

2 

1 

0 

Default »> 

X X 

X 

0 

X 

X 

X 

X 




IliM 


WjH 


1B1 

■n' 

■i 

■I 

H| 

■a 

n| 

n 

1 

■ll 

Default »> 

0 0 

0 

0 

0 

0 

0 

0 


Register 09h 

SCSI Output Control Latch (SOCL) 

ReadlWrite 

REQ 

ACK 

BSY 

SEL 

ATN 

MSG 

C/D 

I/O 

7 

6 

5 

4 

3 

2 

1 

0 

Default »> 







0 

0 

0 

0 

0 

0 

0 

0 

Bit 7 

REQ(Assert SCSI REQ/ Signal) 



Bit 6 

ACK(Assert SCSI ACK/ Signal) 



Bit 5 

BSY(Assert SCSI BSY/ Signal) 




Bit 4 

SEL(Assert SCSI SEL/ Signal) 




Bit 3 

ATN(Assert SCSI ATN/ Signal) 



Bit 2 

MSG(Assert SCSI MSG/ Signal) 



Bit 1 

C/D(Assert SCSI C_D/ Signal) 




BitO 

I/0(Assert SCSI I_0/ Signal) 




Register OAh 







SCSI Selector ID (SSID) 





Read Only 







VAL 

m 

RES 

m 

ENID3 

ENID2 

ENID1 

ENIDO 

7 


S 

4 

3 

2 

1 

0 

Default »> 







0 

X 

X 

X 

0 

0 

0 

0 

Bit 7 

VAL (SCSI Valid) 





Bits 6-4 Reserved 






Bits 3-0 Encoded Destination SCSI ID 




Register OBh 







SCSI Bus Control lines (SBCL) 




Read Only 







■hivlHI 

mMm 


agB 



C/D 

I/O 


■a 

B 

B 

B 

B: 

1 

0 

Default »> 







X 

X 

X 

X 

X 

X 

X 

X 


Bits 7-5,3 Reserved 

Bits 4,2-0 GPIO4-GPIO0 (General Purpose) 


Bit 7 REQ (SREQ/ Status) 

Bit 6 ACK (SACK/ Status) 

Bit 5 BSY (SBSY/ Status) 

Bit 4 SEL (SSEL/ Status) 

Bit 3 ATN (SATN/ Status) 

Bit 2 MSG (SMSG/ Status) 

Bit 1 C/D (SC_D/ Status) 

Bit 0 I/O (SI_0/ Status) 
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Register Summary 

SCSI Registers 


Register OCh 
D2V1A Status (DSTAT) 
Read Only 


DFE 

MDPE 

BF 

ABRT 

SSI 

SIR 

RES 

IID 

7 

6 

5 

4 

3 

2 

1 

0 

Default »> 

1 0 

0 

0 

0 

0 

X 

0 


Bit 7 DFE (DMA FIFO Empty) 

Bit 6 MDPE (Master Data Parity Error) 
Bit 5 BF (Bus Fault) 

Bit 4 ABRT (Aborted) 

Bit 3 SSI (Single Step Interrupt) 

Bit 2 SIR (SCRIPTS Interrupt 

Instruction Received) 

Bit 1 Reserved 

Bit 0 IID (Illegal Instruction Detected) 


Register ODh 

SCSI Status Zero (SSTATO) 
Read Only 


ILF 

ORF 

OLF 

AIP 

LOA 

WOA 

RST/ 

SDPO/ 

7 

6 

5 

4 

3 

2 

1 

0 

Default »> 

0 0 

0 

0 

0 

0 

0 

0 


Bit 7 ILF (SIDL Least Significant Byte Full) 
Bit 6 ORF (SODR Least Significant Byte Full) 

Bit 5 OLF (SODL Least Significant B5rte Full) 

Bit 4 AIP (Arbitration in Progress) 

Bit 3 LOA (Lost Arbitration) 

Bit 2 WOA (Won Arbitration) 

Bit 1 RST/ (SCSI RST/ Signal) 

Bit 0 SDPO/ (SCSI SDPO/ Parity Signal) 


Register OEh 

SCSI Status One (SSTATl) 
Read Only 


FF3 

FF2 

FF1 

FFO 

SDPOL 

MSG 

C/D 

I/O 

7 

6 

5 

4 

3 

2 

1 

0 

Default »> 

0 

0 

0 

0 

X 

X 

X 

X 


Bits 7-4 FF3-FF0 (FIFO Flags) 

Bit 3 SDPOL (Latched SCSI Parity) 

Bit 2 MSG (SCSI MSG/ Signal) 

Bit 1 C/D (SCSI C_D/ Signal) 

Bit 0 I/O (SCSI I_0/ Signal) 


Register OFh 

SCSI Status Two (SSTAT2) 
Read Only 


ILFl 

ORFl 

0LF1 

FF4 

SPLl 

RES 

LDSC 

SDPl 

7 

6 

5 

4 

3 

2 

1 

0 

Default >» 

0 0 

0 

0 

X 

X 

1 

X 


Bit 7 ILFl (SIDL Most Significant Byte Full) 

Bit 6 ORFl (SODR Most Significant Byte Full) 
Bit 5 OLFl (SODL Most Significant Byte Full) 

Bit 4 FF4 (FIFO Flags bit 4) 

Bit 3 SPLl (Latched SCSI parity for SD15-8) 

Bit 2 Reserved 

Bit 1 LDSC (Last Disconnect) 

Bit 0 SDPl (SCSI SDPl Signal) 

Registers 10h-13h 

Data Structure Address (DSA) 

Read/Write 


Register 14h 

Interrupt Status (ISTAT) 
Read/Write 


ABRT 

SRST 

SIGP 

SEM 

CON 

INTF 

SIP 

DIP 

7 

6 

5 

4 

3 

2 

1 

0 

Default »> 

0 0 

0 

0 

0 

0 

0 

0 


Bit 7 ABRT (Abort Operation) 

Bit 6 SRST (Software Reset) 

Bit 5 SIGP (Signal Process) 

Bit 4 SEM (Semaphore) 

Bit 3 CON (Connected) 

Bit 2 INTF (Interrupt on the Fly) 

Bit 1 SIP (SCSI Interrupt Pending) 
Bit 0 DIP (DMA Interrupt Pending) 


Register 18h 

Chip Test Zero (CTESTO) 
Read/Write 


RES RES 


m 

RES 

AP2 

API 

APO 

7 $ 

. 

4-'- 

3 

2 

1 

0 

Default »> 

X X 

X 

X 

X 

0 

0 

0 


Bits 7-3 Reserved 

Bits 2-0 AP2-0 (Arbitration Priority 2-0) 
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SCSI Registers 


PRELIMINARY 


Register 19h 

Chip Test One (CTESTl) 
Read Only 


FMT3 

FMT2 

FMT1 

FMTO 

FFL3 

FFL2 

FFL1 I 

FFLO 

7 

6 

5 

4 

3 

2 

1 

0 

Default »> 







1 

1 

1 

1 

0 

0 

0 

0 

Bits 7-4 
Bits 3-0 

FMT3-0 (Byte Empty in DMA FIFO) 
FFL3-0 (Byte Full in DMA FIFO) 



Register lAh 

Chip Test Two (CTEST2) 
Read Only 





DDIR 

SIGP 

CIO 



TEOP 

DREQ 

DACK 

7 

6 

5 

■i 

■i 

2 

1 

0 

Default »> 







0 

0 

X 

X 

0 

0 

0 

1 

Bit 7 

Bit 6 
Bits 

Bit 4 

Bit 3 

Bit 2 

Bit 1 
BitO 

DDIR (Data Transfer Direction) 

SIGP (Signal Process) 

CIO (Configured as I/O) 

CM (Configured as Memory) 

SRTCH (SCRATCHA/B Operation) 
TEOP (SCSI True End of Process) 
DREQ (Data Request Status) 

DACK (Data Acknowledge Status) 



Register IBh 

Chip Test Three (CTEST3) 
ReadlWrite 





V3 

V2 

VI 

VO 

FLF 

CLF 

FM 

WRIE 

7 

6 

5 

4 

3 

2 

1 

0 

Default »> 







X 

X 

X 

X 

0 

0 

0 

0 


Bits 7-4 V3-V0 (Chip Revision Level) 

Bit 3 FLF (Flush DMA FIFO) 

Bit 2 CLF (Clear DMA FIFO) 

Bit 1 FM (Fetch Pin Mode) 

Bit 0 WRIE (Write and Invalidate Enable) 


Registers ICh-lFh 
Temporary (TEMP) 
ReadWrite 


Register 20h 
DMA FIFO (DFIFO) 
Read! Write 


B07 

7 

B06 

6 

■ 

B04 

4 

B03 

3 

m 

B01 

1 

BOO 

0 

Default »> 







0 

0 

0 

0 

0 

0 

0 

0 

Bits 7-0 

BO7-BO0 (Byte offset counter) 




Register 21h 

Chip Test Four (CTEST4) 
ReadlWrite 


BDIS 

ZMOD 

ZSD 

SRTM 

MPEE 

FBL2 

FBL1 

FBLO 

7 

6 

5 

4 

3 

2 

1 

0 

Default »> 







0 

0 

0 

0 

0 

0 

0 

0 

Bit 7 

Bit 6 
Bits 

Bit 4 

Bit 3 

Bits 2-0 

BDIS (Burst Disable) 

ZMOD (High Impedance Mode) 

ZSD (SCSI Data High Impedance) 
SRTM (Shadow Register Test Mode) 
MPEE (Master Parity Error Enable) 
FBL2-FBL0 (FIFO Byte Control) 



Register 22h 

Chip Test Five (CTEST5) 
ReadlWrite 





ADCK 

BBCK 

DFS 

MASR 

DDIR 

BL2 

B09 

BOB 

7 

6 

5 

4 

3 

2 

1 

0 

Default »> 







0 

0 

0 

0 

0 

0 

0 

0 

Bit 7 

Bit 6 
Bits 

Bit 4 

Bit 3 

Bit 

Bits 1-0 

ADCK (Clock Address Incrementor) 

BBCK (Clock Byte Counter) 

DFS (DMA FIFO Size) 

MASR (Master Control for Set or Reset Pulses) 

DDIR (DMA Direction) 

BL2 (Burst Length bit 2) 

B09-B08 (DMA FIFO Byte Offset Counter, bits 9-8) 


Register 23h 

Chip Test Six (CTEST6) 

ReadlWrite 


DF7 

DF6 

DFS 

DF4 

DF3 

DF2 

DF1 

DFO 

7 

6 

5 

4 

3 

2 

1 

0 

Default »> 

0 0 

0 

0 

0 

0 

0 

0 


Bits 7-0 DF7-DF0 (DMA FIFO) 
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Register Summary 

SCSI Registers 


Registers 24h-26h 

DMA Byte Counter (DBG) 

ReadlWrite 


Register 27h 

DA4A Command (DCMD) 
ReadlWrite 


Registers 28h-2Bh 

DMA Next Address (DNAD) 

ReadlWrite 


Registers 2Ch-2Fh 

DMA SCRIPTS Pointer (DSP) 

ReadlWrite 


Registers 30h-33h 

DMA SCRIPTS Pointer Save (DSPS) 
ReadlWrite 


Registers 34h 

Scratch Register A (SCRATCHA) 
ReadlWrite 


Register 38h 

DMA Mode(DMODE) 

ReadlWrite 


BL1 

BLO 

SIOM 

DIOM 

ER 

ERMP 

BOF 

MAN 

7 

6 

5 

4 

3 

2 

1 

0 


Default »> 


00000000 

Bit 7-6 BLl-BLO (Burst Length) 

Bit 5 SIOM (Source I/O-Memory Enable) 

Bit 4 DIOM (Destination I/O-Memory Enable) 

Bit 3 ERL (Enable Read Line) 

Bit 2 ERMP (Enable Read Multiple) 

Bit 1 BOF (Burst Op Code Fetch Enable) 

Bit 0 MAN (Manual Start Mode) 


Register 39h 

DMA Interrupt Enable (DIEN) 
ReadlWrite 


RES 


BF 

ABRT 

SSI 

SIR 

RES 

IID 

7 

6 

5 

4 

3 

2 

1 

0 

Default »> 

X 0 

0 

0 

0 

0 

X 

0 


Bit 7 Reserved 

Bit 6 MDPE (Master Data Parity Error) 

Bit 5 BF (Bus Fault) 

Bit 4 ABRT (Aborted) 

Bit 3 SSI (Single -step Interrupt) 

Bit 2 SIR (SCRIPTS Interrupt 

Instruction Received 
Bit 1 Reserved 

Bit 0 IID (Illegal Instruction Deteaed) 


Register 3Ah 

Scratch Byte Register (SBR) 
ReadlWrite 


Register 3Bh 

DMA Control (DCNTL) 

ReadlWrite 


CLSE 

PFF 

PFEN 

SSM 

INTM 

STD 

INTD 

COM 

7 

6 

5 

4 

3 

2 

1 

0 

Default »> 

0 0 

0 

0 

0 

0 

0 

0 


Bit 7 CLSE (Cache Line Size Enable) 
Bit 6 PFF (Pre-fetch Flush) 

Bit 5 PFEN (Pre-fetch Enable) 

Bit 4 SSM (Single-step Mode) 

Bit 3 INTM (INTA Mode) 

Bit 1 IRQD (INTA, INTB Disable) 

Bit 0 COM (53C700 Compatibility) 


Register 3Ch-3Fh 

Adder Sum Output (ADDER) 

Read Only 
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Register 40h 

SCSI Interrupt Enable Zero (SIENO) 
Read/Write 



Register 43h 

SCSI Interrupt Status One (SISTl) 
Read Only 



Bit 7 M/A (SCSI Phase Mismatch - 
Initiator Mode; SCSI ATN 
Condition -Thrget Mode) 

Bit 6 CMP (Function Complete) 

Bit 5 SEL (Selected) 

Bit 4 RSL (Reseleaed) 

Bit 3 SGE (SCSI Gross Error) 

Bit 2 UDC (Unexpected Disconnect) 

Bit 1 RST (SCSI Reset Condition) 

Bit 0 PAR (SCSI Parity Error) 


Bits 7-4 Reserved 

Bit 2 STO (Selection or Reselection Time-out) 

Bit 1 GEN (General Purpose Timer Expired) 

Bit 0 HTH (Handshake-to-Handshake Timer Expired) 


Register 44h 

SCSI Longitudinal Parity (SLPAR) 
ReadfWrite 


Register 41h 

SCSI Interrupt Enable One (SIENl) 
ReadlWrite 


RES 


m 



STO 

GEN 

HTH 

7 

6 

'' 5^' 

4 

3 

2 

1 

0 

Default »> 
X 

X 

X 

X 

X 

0 

0 

0 


Bits 7-3 Reserved 

Bit 2 STO (Selection or Reselection Time-out) 

Bit 1 GEN (General Purpose Timer Expired) 

Bit 0 HTH ( Handshake-to-Handshake Timer Expired) 


Register 45h 

SCSI Wide Residue (SWIDE) 
ReadlWrite 


Register 46h 

Memory Access Control (MACNTL) 
ReadlWrite 


TYP3 

TYP2 

TYP1 

TYPO 

RES 

RES 

RES I 

RES 

7 

6 

5 

4 

3 

2 

1 ! 

6 

Default »> 

0 1 

1 

1 

X 

X 

X 

X 


Register 42h 

SCSI Interrupt Status Zero (SISTO) 
Read Only 


M/A 

CMP 

SEL 

RSL 

SGE 

UDC 

RST 

PAR 

7 

6 

5 

4 

3 

2 

1 

0 

Default »> 

0 0 

0 

0 

0 

0 

0 

0 


Bit 7 M/A (Initiator Mode: Phase Mismatch;Target Mode: 
SATN/ Active) 

Bit 6 CMP (Function Complete) 

Bit 5 SEL (Selected) 

Bit 4 RSL (Reseleaed) 

Bit 3 SGE (SCSI Gross Error) 

Bit 2 UDC (Unexpeaed Disconnea) 

Bit 1 RST (SCSI RST/ Received) 

Bit 0 PAR (Parity Error) 


Bits 7-4 TYP3-0 (Chip Type) 

Bit 3-0 Reserved 


Register 47h 

General Purpose Pin Control (GPCNTL) 
ReadlWrite 


ME 

FE 

RES 

GPI04 

GPI03 

GPI02 

GPI01 

GPlOO 

7 

6 

5 

4 

3 

2 

1 

0 

Default »> 

0 

0 

X 

0 

1 

1 

1 

1 


Bit 7 Master Enable 

Bit 6 Fetch Enable 

Bits 5 Reserved 

Bits 4,2 GPI04_EN-GPI02_EN (GPIO Enable) 

Bits 1-0 GPI01_EN-GPIOO_EN (GPIO Enable) 
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SCSI Registers 


Register 48h 

SCSI Timer Zero (STIMEO) 

Read! Write 


HTH7 

HTH6 

HTH5 

HRH4 

7 

6 

5 

4 

Default »> 

0 0 

0 

0 



Register 4Ch 

SCSI Test Zero (STESTO) 

Read Only 


SSAID3 

SSAID2 

SSAID1 

SSAIDO 

SLl 

7 

6 

5 

4 

3 

Default >» 

0 0 

0 

0 

0 


SOZ 

SOM 

1 

0 


1 1 


Bits 7-4 HTH (Handshake-to-Handshake Timer Period) 

Bits 3-0 SEL (Seleaion Time-Out) 


Register 49h 

SCSI Timer One (STIMEl) 

Read/Wnte 


RES HTHBA 

7 6 

GENSF 

5 

HTHSF 

4 

GENS 

3 

GEN2 

2 

GEN1 

1 

GENO 

0 

Default »> 

X 0 

0 

0 

0 

0 

0 

0 


Bit 7 Reserved 

Bit 6 HTHBA (Handshake-to-Handshake Timer Bus Activity 

Enable) 

Bit 5 GENSF (General Purpose Timer Scale Factor) 

Bit 4 HTHSF (Handshake to Handshake Timer Scale Factor) 
Bits 3-0 GEN3-0 (General Purpose Timer Period) 


Register 4Ah 

Response ID Zero (RESPIDO) 

Read/Write 


ID 

ID 

ID 

ID 

ID 

ID 

ID 

ID 

7 

6 

5 

4 

3 

2 

1 

0 


Default »> 

X X X X X X X X 


Register 4Bh 

Response ID One (RESPIDl) 

Read/Write 


ID 

ID 

ID 

ID 

ID 

ID 

ID 

ID 

15 

14 

13 

12 

11 

10 

9 

8 

Default »> 

X 

X 

X 

X 

X 

X 

X 

X 


Bits 7-4 SSAID3-0 (SCSI Selected As ID) 

Bit 3 SLT (Selection Response Logic Test) 

Bit 2 ART (Arbitration Priority Encoder Test) 

Bit 1 SOZ (SCSI Synchronous Offset Zero) 

Bit 0 SOM (SCSI S 3 mchronous Offset Maximum) 


Register 4Dh 
SCSITest One (STESTl) 
Read! Write 



OOXX 0 OXX 


Bit 7 SCLK 

Bit 6 ISO_MODE (SCSI Isolation Mode) 
Bit 5 Reserved 

Bit 4 Reserved 

Bit 3 DBLEN (SCLK Doubler Enable) 

Bit 2 DBLSEL (SCLK Doubler Select) 

Bits 1-0 Reserved 


Register 4Eh 

SCSITest Two (STEST2) 

Read/Write 



00000000 


Bit 7 SCE (SCSI Control Enable) 

Bit 6 ROF (Reset SCSI Offset) 

Bit 5 DIF 

Bit 4 SUB (SCSI Loopback Mode) 

Bit 3 SZM (SCSI High-Impedance Mode) 
Bit 2 AWS (Always Wide SCSI) 

Bit 1 EXT (Extend SREQ/SACK 

Filtering) 

Bit 0 LOW (SCSI Low level Mode) 
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Register 4Fh 

SCSITestThree (STEST3) 
ReadlWrite 


TE 

STR 

HSC 

DSI 

DIFF 

niwi 

CSF 

STW 

7 

6 

5 

4 

3 

2 

1 

0 

Default »> 

0 0 

0 

0 

X 

0 

0 

0 


Bit 7 TE (TolerANT Enable) 

Bit 6 STR (SCSI FIFO Test Read) 

Bit 5 HSC (Halt SCSI Clock) 

Bit 4 DSI (Disable Single Initiator Response) 
Bit 3 DIFF DIFFSENSE Sense 

Bit 2 TTM (Timer Test Mode) 

Bit 1 CSF (Clear SCSI FIFO) 

BitO STW (SCSI FIFOTestWrite) 


Register 50h-51h 

SCSI Input Data Latch (SIDL) 

Read Only 


Registers 54h-55h 

SCSI Output Data Latch (SODL) 

ReadlWrite 


Registers 58h-59h 

SCSI Bus Data Lines (SBDL) 

Read Only 


Registers SCh-SFh 

Scratch Register B (SCRATCHB) 

ReadlWrite 


Registers 60h-7Fh 
Scratch Registers C-J 
(SCRATCHC-SCRATCHJ) 
ReadlWrite 
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Mechanical Drawings 


Appendix B 

Mechanical Drawings 



Pin 11ndicator 


208-Pin Plastic 
Quad Flat Package (QFP) 





0.810.15 — 


31.9010.25 


0.25 Max 
0.18 Min 


Figure B-1;SYM53C876 208-Pin PQFP Mechanical Drawing 
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B-2 



0.36 NOM 


Side View 



Top View 


20 19 18 17 16 IS 14 13 12 11 10 9 8 7 6 5 4 3 2 1 


0.76 NOM 



Pad #1, A1 Corner 


Bottom View 


All dimensions In millimeters 


Fig:ure B-2:SYMS3C876 256-Bump PBGA Mechanical Drawing 
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Appendix C 

External Memory Interface Diagram Examples 



MAD Bus Sense Logic Enabled for 16 KB of slow memory (200 ns Device @ 33MHz) 

Figure C-l:16 K Interface With 200 ns Memory 
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External Memory Interface Diagram Examples 
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SYIVI53C876 


Optional - for Flash Memory only, 



MAD Bus Sense Logic Enabled for 64 KB of fast memory (150 ns Device @ 33MHz) 


Figure C-2:64 K Interface with 150 ns Memory 
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External Memory Interface Diagram Examples 


SYM53C876 


Optional - for Flash Memory only, 



MAD Bus Sense Logic Enabled for 256 KB of fast memory (150 ns Device @ 33MHz). 
The HCT374S may be replaced with HCT377S. 


Figure C-3:256 K Interface With 150 ns Memory 
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MAD Bus Sense Logic Enabled for 512 KB of slow memory (150 ns Devices, additional time required for HCT139 @ 33MHz). 

The HCT374S may be replaced with HCT377s. 
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Index 


Index 


Numerics 

3.3/5 Volt PCI interface. 2-6, 2-10 
40 MHz clock doubler, 2-19 
53C700 Compatibility bit, 4-48, A-7 

A 

Abort Operation bit, 4-33, A-5 
Aborted bit, 4-29, 4-46, A-5, A-7 
Absolute Maximum Stress Ratings, 6-1 
active negation 

see Toler ANT Technology 
active termination, 2-18 
AD(31-0), 3-6 
ADDER register, 4-49, A-7 
Adder Sum Output register, 4-49, A-7 
Address/Data bus, 2-2 
Address/Data Pins, 3-6 
Alignment, 2-7 

Alternative Two Termination, 2-18 
Alwys Wide SCSI bit, 4-62, A-9 
Arbitation in Progress bit, 4-30, A-5 
arbitration 

Arbitration in Progress bit, 4-30, A-5 
Arbitration Mode bits, 4-17, A-3 
Immediate Arbitration bit, 4-20, A-3 
Lost Arbitration bit, 4-30, A-5 
Won Arbitration bit, 4-30, A-5 
Arbitration Mode bits, 4-17, A-3 
Arbitration Pins, 3-8 

Arbitration Priority Encoder Test bit, 4-59, A-9 
ASPI, 1-3 

Assert Even SCSI Parity bit, 4-19, A-3 
Assert S ATN/ on Parity Error bit, 4-18, A-3 
Assert SCSI ACK/Signal bit, 4-27, A-4 
Assert SCSI ATN/ Signal bit, 4-27, A-4 
Assert SCSI BSY/ Signal bit, 4-27, A-4 
Assert SCSI C_D/Signal bit, 4-27, A-4 


Assert SCSI Data Bus bit, 4-19, A-3 
Assert SCSI I_0 Signal bit, 4-27, A-4 
Assert SCSI MSG/Signal bit, 4-27, A-4 
Assert SCSI REQ/ Signal bit, 4-27, A-4 
Assert SCSI RST/Signal bit, 4-19, A-3 
Assert SCSI SEL/ Signal bit. 4-27, A-4 
Asynchronous SCSI Receive, 2-14 
Asynchronous SCSI Send, 2-13 
Auto-Configuration Disable, 3-18 

B 

Base Address Register One, 2-2 
bi-directional, 3-4 
BIOS, 2-2 
BIOS ROM, 1-1 

Bits Used for Parity Control and Generation, 2-11 
Block Move and Chained Block Move Instruc¬ 
tions, 2-26 

Block Move Instructions, 5-4 

BSYDIR, 3-13 

Burst Disable bit, 4-39, A-6 

Burst Length bits, 4-41,4-45, A-6, A-7 

Burst Op Code Fetch Enable bit, 4-45, A-7 

Burst Size Selection, 2-4 

Bus command and byte enables, 3-6 

Bus Fault bit, 4-28,4-46, A-5, A-7 

Byte Empty in DMA FIFO bit, 4-36, A-6 

Byte Full in DMA FIFO bit, 4-36, A-6 

Byte Offset Counter bits, 4-39,4-41, A-6 

C 

C_BE/ (3-0), 2-2, 3-6 
Cache Line Size Enable bit, 4-48, A-7 
Cache Line Size Register, 2-4 
cache mode, see PCI cache mode, 2-6 
CCF2-0, 2-19 

Chained Block Move SCRIPTS Instruction, 2-25 
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chained block moves, 2-24-2-26 
SODL register, 2-25 
SWIDE register, 2-25 
Wide SCSI Receive Bit, 2-24 
Wide SCSI Send Bit, 2-24 
Chained Mode bit, 4-21, A-3 
Chip Revision Level bits, 4-37, A-6 
Chip Test Five register, 4-40, A-6 
Chip Test Four register, 4-39, A-6 
Chip Test One register, 4-36, A-6 
Chip Test Six register, 4-41, A-6 
Chip Test Two register, 4-36, A-6 
Chip Test Zero register, 4-35, A-5 
Chip Type bits, 4-56, A-8 
CHMOV, 2-24 
Clear DMA FIFO, 2-23 
Clear DMA FIFO bit, 4-37, A-6 
Clear SCSI HFO bit, 4-63, A-10 
CLF, 2-23 
CLK, 3-5 
Clock, 3-5 

Clock Address Incrementor bit, 4-40, A-6 
Clock Byte Counter bit, 4-40, A-6 
Clock Conversion Factor, 2-19 
Clock Conversion Factor bits, 4-23, A-3 
CLSE, 2-4,2-5 
CMP, 2-22 

Configuration Read Command, 2-3 
Configuration Space, 2-2 
Configuration space, 2-2 
Configuration Write Command, 2-4 
Configured as I/O bit, 4-36, A-6 
Configured as Memory bit, 4-36, A-6 
Connected bit, 4-19,4-34, A-3, A-5 
Conventions, 1-5 
CSF, 2-23 

CTESTO register, 4-35, A-5 
CTESTl register. 4-36, A-6 
CTEST2 register, 4-36, A-6 
CTEST4 register, 4-39, A-6 
CTEST5 register, 4-40, A-6 
CTEST6 register, 4-41, A-6 
Cycle Frame, 3-7 


D 

Data Acknowledge Status bit, 4-37, A-6 
datapath, 2-13 
Datapaths, 2-13 

Data Request Status bit, 4-37, A-6 

Data Structure Address register, 4-33, A-5 

Data Transfer Direction bit, 4-36, A-6 

Data-In, 2-25 

Data-Out, 2-25 

DBC register, 4-42, A-7 

DCMD register, 4-42, A-7 

DCNTL, 2-4,2-22 

DCNTL register, 4-48, A-7 

Decode of MAD pins, 3-18 

Designing an Ultra SCSI System, 2-20 

Destination I/0-Memoiy Enable bit, 4-45, A-7 

Determining the Data Transfer Rate, 2-19 

Determining the Synchronous Transfer Rate, 2-20 

Device Select, 3-7 

DEVSEL/, 3-7 

DFIFO register, 4-39, A-6 

DIEN, 2-22 

DIEN register, 4-46. A-7 
differential mode 
operation, 2-15 
DIFFSENS, 3-13,3-14 
DIP, 2-21,2-23 
DIP bit, 2-24 

Disable Halt on Parity Error or ATN, 4-19, A-3 

Disable Single Initiator Response bit, 4-63, A-10 

DMA Byte Counter register, 4-42, A-7 

DMA Command register, 4-42, A-7 

DMA Control register, 4-48, A-7 

DMA core, 1-3 

DMA Direction bit, 4-41, A-6 

DMA FIFO, 2-5,2-13,2-21 

DMA FIFO bits, 4-41, A-6 

DMA FIFO Empty bit, 4-28, A-5 

DMA FIFO register, 4-39, A-6 

DMA FIFO Sections, 2-13 

DMA Interrupt Enable register, 4-46, A-7 

DMA Interrupt Pending bit, 4-35, A-5 

DMA interrupts, 2-22,2-23 

DMA Mode register, 4-45, A-7 
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DMA Next Address register, 4-43, A-7 

DMA SCRIPTS Pointer register, 4-43, A-7 

DMA SCRIPTS Pointer Save register, 4-44, A-7 

DMA Status register, 4-28, A-5 

DMODE, 2-4 

DMODE Register, 2-9 

DMODE register, 4-45, A-7 

DNAD register, 4-43, A-7 

DSA register, 4-33, A-5 

DSP register, 4-43, A-7 

DSPS register, 4-44, A-7 

DSTAT, 2-21,2-23,2-24 

DSTAT register, 4-28, A-5 

Dual Address Cycles Command, 2-4 

E 

Enable Parity Checking, 2-10 
Enable Parity Checking bit, 4-18, A-3 
Enable Read Line bit, 4-45, A-7 
Enable Read Multiple bit, 4-45, A-7 
Enable Response to Reselection bit, 4-23, A-4 
Enable Response to Selection bit, 4-23, A-4 
Enable Wide SCSI bit, 4-23, A-3 
Encoded Chip SCSI ID, 4-23, A-4 
Encoded Destination SCSI ID bit, 4-27, A-4 
Encoded Destination SCSI ID bits, 4-25, A-4 
EPROMs, 1-1 
Error Recording Pins, 3-8 
Even Parity, 2-10 
Expanded Register Move, 1-4 
Expansion ROM Base Address Register, 2-27 
Extend SREQ/SACK Filtering bit, 4-62, A-9 
external memory interface, 2-27 
configuration, 2-27 
GPI04bit, 4-26, A-4 
slow memory, 2-27 

Extra Clock Cycle of Data Setup bit, 4-19, A-3 

F 

Fetch Enable, 4-56, A-8 
Fetch Pin Mode bit, 4-38, A-6 
FIFO Byte Control bits, 4-40, A-6 
FIFO Flags bits, 4-31,4-32, A-5 
Flush DMA FIFO bit, 4-37, A-6 


FRAME/, 3-7 

Function Complete, 2-22 

Function Complete bit, 4-50,4-52, A-8 

G 

General Purpose I/O pin 0, 3-10 
General purpose I/O pin 1, 3-10 
General Purpose I/O pin 2, 3-10 
General purpose I/O pin 3, 3-10 
General purpose I/O pin 4, 3-10 
General Purpose Pin Control register, 4-56, A-8 
General Purpose register, 4-26, A-4 
General Purpose Timer Expired bit, 4-51,4-53, A- 
8 

General Purpose Timer Period bits, 4-58, A-9 
General Purpose Timer Scale Factor bit, 4-58, A-9 
GNT/, 3-8 

GPCNTL register, 4-56, A-8 
GPI00_ FETCH/, 3-10 
GPIO Enable bit, 4-56, A-8 
GPIO Interface Pins, 3-10 
GPI01_ MASTER/, 3-10 
GPI02, 3-10 
GPI03, 3-10 
GPI04, 3-10 
GPIO4-0bits, 4-26, A-4 
GPREG register, 4-26, A-4 
Grant, 3-8 

H 

Halt SCSI Clock bit, 4-63, A-10 
Handshake-to-Handshake Timer Bus Activity En¬ 
able bit, 4-58, A-9 

Handshake-to-Handshake Timer Expired bit, 4- 
51,4-54, A-8 

Handshake-to-Handshake Timer Period bit, 4-57, 
A-9 

Hardware Interrupts, 2-21 

High Impedance Mode bit, 4-39, A-6 

I 

I/O Instructions, 5-8 
I/O Read Conunand, 2-3 
I/O Space, 2-2 
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I/O space, 2-2 
I/O Write Command, 2-3 
IDSEL, 2-2, 3-7 
IDSEL signal, 2-3 
IGS, 3-13,3-14 

Illegal Instruction Detected bit, 4-29, A-5 
Immediate Arbitration bit, 4-20, A-3 
Initialization Device Select, 3-7 
Initiator Ready, 3-7 
Input, 3-4 

instruction prefetching, 2-9 

Pre-fetch Enable bit, 4-48, A-7 
Pre-fetch Flush bit, 4-48, A-7 
prefetch unit flushing, 2-9 
instructions 

block move, 5-4 
I/O, 5-8 

load and store, 5-23 
memory move, 5-20 
read/write, 5-13 
transfer control, 5-16 
INTA routing enable, 3-18 
INTA/, 2-21,3-9,3-18 
INTA/pin, 2-22,2-24 
INTB/, 3-9,3-18 
Integration, 1-4 
Interface Control Pins, 3-7 
Internal Arbiter, 2-6 

internal RAM, see also SCRIPTS RAM, 2-8 
Internal SCRIPTS RAM, 2-8 
Interrupt A, 3-9 
Interrupt B, 3-9 

Interrupt on the Fly bit, 4-34, A-5 
Interrupt Request, 2-21 
Interrupt Status register, 4-33, A-5 
Interrupts, 2-22 
interrupts, 2-21 

fatal vs. non-fatal interrupts, 2-22 
halting, 2-23 
IRQ Disable bit, 2-22 
masking, 2-22 

sample interrupt service routine, 2-24 
stacked interrupts, 2-23 


IRDY/, 3-7 

IRQ Disable bit, 4-48, A-7 
ISTAT, 2-21,2-24 
ISTAT register, 4-33, A-5 

L 

Last Disconnect bit, 4-32, A-5 
Latched SCSI Parity bit, 4-31, A-5 
Latched SCSI Parity for SD15-8 bit, 4-32, A-5 
Latency, 2-6 

load and store instructions, 5-23 
no flush option, 5-23 

prefetch unit and Store instructions, 2-9, 5-23 
Load and Store SCRIPTS, 1-4 
Load/Store Instructions, 2-9 
Lost Arbitration bit, 4-30, A-5 

M 

MACNTL register, 4-56, A-8 
MAD bus, 2-27 
MAD Bus Programming, 3-18 
MAD pins, 2-27 
MAD(7-0) pins, 3-18 
MAD7-0, 3-15 

Manual Start Mode bit, 4-46, A-7 
MASO/, 3-15 
MASl/, 3-15 
Masking, 2-22 

Master Control for Set or Reset Pulses bit, 4-40, 
A-6 

Master Data Parity Error bit, 4-28,4-46, A-5, A-7 
Master Enable bit, 4-56, A-8 
Master Parity Error Enable bit, 4-40, A-6 
Max SCSI Synchronous Offset bits, 4-25, A-4 
MCE/, 3-15 

Memory Access Control register, 4-56, A-8 
Memory Address Strobe 0, 3-15 
Memory Address Strobe 1, 3-15 
Memory Address/Data Bus, 3-15 
Memory Chip Enable, 3-15 
Memory Move instruction, 2-7 
Memory Move instructions, 5-20 

and SCRIPTS instruction prefetching, 2-9 
No Flush option, 2-9 
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Memory Move Misalignment, 2-7 
Memory Output Enable, 3-15 
Memory Read Command, 2-3 
Memory Read Line Command, 2-4 
Memory Read Multiple Command, 2-4 
Memory Space, 2-2 
Memory space, 2-2 

Memory Write and Invalidate Command, 2-5 

Memory Write Command, 2-3 

Memory Write Enable, 3-15 

MOE_TESTOUT, 3-15 

Multiple Cache Line Transfers, 2-5 

multi-threaded I/O, 1-4 

MWE/, 3-15 

N 

No Flush Memory Move instruction, 5-21 

O 

Objectives of DMA architecture, 2-27 
Op Code Fetch Burst Capability, 2-9 
op code fetch bursting, 2-9 
Operating Conditions, 6-1 
operating registers 

Adder Sum Output, 4-49, A-7 

Chip Test Five, 4-40, A-6 

Chip Test Four, 4-39, A-6 

Chip Test One, 4-36, A-6 

Chip Test Six, 4-41, A-6 

Chip Test Three, 4-37, A-6 

Chip Test Two, 4-36, A-6 

Chip Test Zero, 4-35, A-5 

Data Structure Address, 4-33, A-5 

DMA Byte Counter, 4-42, A-7 

DMA Command, 4-42, A-7 

DMA Control, 4-48, A-7 

DMA FIFO, 4-39, A-6 

DMA Interrupt Enable, 4-46, A-7 

DMA Mode, 4-45, A-7 

DMA Next Address, 4-43, A-7 

DMA SCRIPTS Pointer, 4-43, A-7 

DMA SCRIPTS Pointer Save, 4-44, A-7 

DMA Status, 4-28, A-5 

General Purpose, 4-26, A-4 


General Purpose Pin Control, 4-56, A-8 
Interrupt Status, 4-33, A-5 
Memory Access Control, 4-56, A-8 
register address map, 4-16 
Response ID One, 4-59, A-9 
Response ID Zero, 4-58, A-9 
Scratch Register A, 4-44, A-7 
Scratch Register B, 4-65, A-10 
SCSI Bus Control Lines, 4-28, A-4 
SCSI Bus Data Lines, 4-65, A-10 
SCSI Chip ID, 4-23, A-4 
SCSI Control One register, 4-19, A-3 
SCSI Control Register Two, 4-21, A-3 
SCSI Control Three, 4-22, A-3 
SCSI Control Zero, 4-17, A-3 
SCSI Destination ID, 4-25, A-4 
SCSI First Byte Received, 4-26, A-4 
SCSI Input Data Latch, 4-64, A-10 
SCSI Interrupt Enable One, 4-51, A-8 
SCSI Interrupt Enable Zero, 4-50, A-8 
SCSI Interrupt Status One, 4-53, A-8 
SCSI Interrupt Status Zero, 4-52, A-8 
SCSI Longitudinal Parity, 4-54, A-8 
SCSI Output Control Latch, 4-27, A-4 
SCSI Output Data Latch, 4-64, A-10 
SCSI Selector ID, 4-27, A-4 
SCSI Status One, 4-31, A-5 
SCSI Status Two, 4-32, A-5 
SCSI Status Zero, 4-30, A-5 
SCSI Test One, 4-60, A-9 
SCSI Test Three, 4-62, A-10 
SCSI Test Two, 4-61, A-9 
SCSI Test Zero, 4-59, A-9 
SCSI Timer One, 4-58, A-9 
SCSI Timer Zero, 4-57, A-9 
SCSI Transfer, 4-24, A-4 
SCSI Wide Residue, 4-55, A-8 
Temporary Stack, 4-38, A-6 


P 

PAR, 3-6 

Parallel ROM Interface, 2-27 
Parallel ROM Support, 2-27 
Parity, 2-10-2-12,3-6 
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Parity Error, 3-8 
Parity Error bit, 4-53, A-8 
PCI Addressing, 2-2 

PCI Bus Commands and Encoding Types, 2-3 
PCI Bus Commands and Functions Supported, 2- 
2 

PCI Cache Line Size Register, 2-5 
PCI cache mode, 2-6 

Cache Line Size Enable bit, 4-48, A-7 
Enable Read Multiple bit, 4-45, A-7 
Write and Invalidate Enable bit, 4-38, A-6 
PCI commands, 2-2 
PCI configuration registers, 4-1-?? 

PCI Functional Description, 2-2 
PCI I/O space, 2-2 
PCI Interface Pins, 3-5, 3-7 
PCI Interrupt Pins, 3-9 
PCI memory space, 2-2 
PCI Performance, 1-4 
PCI Target Disconnect, 2-6 
PCI Target Retry, 2-6 
PERR/, 3-8 

Phase Mismatch bit, 4-52, A-8 
Physical longword address and data, 3-6 
Pin Diagram, 3-1 
Polling, 2-21 

Pre-fetch Enable bit, 4-48, A-7 
Pre-fetch Flush bit, 4-48, A-7 

R 

RAM, see also SCRIPTS RAM, 2-8 
Read Line Mode, 2-4 

Read Multiple with Read Line Enabled, 2-5 
Read/Write Instructions, 5-13 
Register Addresses 
operating registers 
Olh, 4-19, A-3 
02h, 4-21, A-3 
03h, 4-22, A-3 
04h, 4-23, A-4 
05h, 4-24, A-4 
06h, 4-25, A-4 
07h, 4-26, A-4 
08h, 4-26, A-4 


09h, 4-27, A-4 
OAh, 4-27, A-4 
OBh, 4-28, A-4 
OCh, 4-28, A-5 
ODh, 4-30, A-5 
OEh, 4-31, A-5 
OFh, 4-32, A-5 
10-13h, 4-33, A-5 
14h, 4-33, A-5 
18h, 4-35, A-5 
19h, 4-36, A-6 
lAh, 4-36, A-6 
IBh, 4-37, A-6 
IC-lFh, 4-38, A-6 
20h, 4-39, A-6 
21h, 4-39, A-6 
22h, 4-40, A-6 
23h, 4-41. A-6 
24-26h, 4-42, A-7 
27h, 4-42, A-7 
28-2Bh, 4-43, A-7 
2C-2Fh, 4-43, A-7 
30-33h. 4-44, A-7 
34-37h, 4-44, A-7 
38h, 4-45, A-7 
39h, 4-46, A-7 
3Ah, 4-47, A-7 
3Bh, 4-48, A-7 
3C-3Fh. 4-49, A-7 
40h, 4-50, A-8 
41h, 4-51, A-8 
42h, 4-52, A-8 
43h, 4-53, A-8 
44h. 4-54, A-8 
45h, 4-55, A-8 
46h, 4-56, A-8 
47h, 4-56, A-8 
48h, 4-57, A-9 
49h, 4-58, A-9 
4Ah, 4-58, A-9 
4Bh, 4-59, A-9 
4Ch, 4-59, A-9 
4Dh, 4-60, A-9 
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4Eh. 4-61, A-9 
4Fh, 4-62, A-10 
50-51h, 4-64, A-10 
54-55h, 4-64, A-10 
58-59h, 4-65, A-10 
5C-5Fh, 4-65, A-10 
60-70h, 4-66, A-10 
Register Bits 

53C700 Compatibility, 4-48, A-7 
Abort Operation, 4-33, A-5 
Aborted, 4-29,4-46, A-5, A-7 
Always Wide SCSI, 4-62, A-9 
Arbitration in Progress, 4-30, A-5 
Arbitration Mode, 4-17, A-3 
Arbitration Priority Encoder Test, 4-59, A-9 
Assert Even SCSI Parity (force bad parity)), 4- 
19, A-3 

Assert SATN/ on Parity Error, 4-18, A-3 
Assert SCSI ACKJ Signal, 4-27, A-4 
Assert SCSI ATN/ Signal, 4-27, A-4 
Assert SCSI BSY/ Signal, 4-27, A-4 
Assert SCSI C_D/ Signal, 4-27, A-4 
Assert SCSI Data Bus, 4-19, A-3 
Assert SCSI I_0/ Signal, 4-27, A-4 
Assert SCSI MSG/ Signal, 4-27, A-4 
Assert SCSI REQ/ Signal), 4-27, A-4 
Assert SCSI RST/ Signal, 4-19, A-3 
Assert SCSI SEL/ Signal, 4-27, A-4 
Burst Disable, 4-39, A-6 
Burst Length, 4-41,4-45, A-6, A-7 
Burst Op Code Fetch Enable, 4-45, A-7 
Bus Fault, 4-28,4-46, A-5, A-7 
Byte Empty in DMA FIFO, 4-36, A-6 
Byte Full in DMA FIFO, 4-36, A-6 
Byte Offset Counter, 4-39,4-41, A-6 
Cache Line Size Enable, 4-48, A-7 
Chained Mode, 4-21, A-3 
Chip Revision Level, 4-37, A-6 
Chip Type, 4-56, A-8 
Clear DMA HFO, 4-37, A-6 
Clear SCSI HFO, 4-63, A-10 
Clock Address Incrementor, 4-40, A-6 
Clock Byte Counter, 4-40, A-6 
Clock Conversion Factor, 4-23, A-3 


Configured as I/O, 4-36, A-6 
Configured as Memory, 4-36, A-6 
Connected, 4-19, 4-34, A-3, A-5 
Data Acknowledge Status, 4-37, A-6 
Data Request Status, 4-37, A-6 
Data Transfer Direction, 4-36, A-6 
Destination I/O-Memory Enable, 4-45, A-7 
Disable Halt on Parity Error or ATN, 4-19, A- 
3 

Disable Single Initiator Response, 4-63, A-10 
DMA Direction, 4-41, A-6 
DMA FIFO, 4-41, A-6 
DMA FIFO Empty, 4-28, A-5 
DMA Interrupt Pending, 4-35, A-5 
Enable Parity Checking, 4-18, A-3 
Enable Read Line, 4-45, A-7 
Enable Read Multiple, 4-45, A-7 
Enable Response to Reselection, 4-23, A-4 
Enable Response to Selection, 4-23, A-4 
Enable Wide SCSI, 4-23, A-3 
Encoded Chip SCSI ID, bits 3-0, 4-23, A-4 
Encoded Destination SCSI ID, 4-25,4-27, A-4 
Extend SREQ/SACK Filtering, 4-62, A-9 
Extra clock cycle of data setup, 4-19, A-3 
Fetch Enable, 4-56, A-8 
Fetch Pin Mode, 4-38, A-6 
FIFO Byte Control, 4-40, A-6 
FIFO Flags, 4-31,4-32, A-5 
Flush DMA FIFO, 4-37, A-6 
Function Complete, 4-50, 4-52, A-8 
General Purpose Timer Expired, 4-51, 4-53, 
A-8 

General Purpose Timer Period, 4-58, A-9 
General Purpose Timer Scale Factor, 4-58, A- 
9 

GPIO Enable, 4-56, A-8 
GPIO4-0, 4-26, A-4 
Halt SCSI Clock, 4-63, A-10 
Handshake-to-Handshake Timer Bus Activity 
Enable, 4-58, A-9 

Handshake-to-Handshake Timer Expired, 4- 
51,4-54, A-8 

Handshake-to-Handshake Timer Period, 4-57, 
A-9 
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High Impedance Mode, 4-39, A-6 
Illegal Instruction Detected, 4-29, A-5 
Illegal instruction detected, 4-47, A-7 
Immediate Arbitration, 4-20, A-3 
Interrupt on the Fly, 4-34, A-5 
IRQ Disable, 4-48, A-7 
Last Disconnect, 4-32, A-5 
Latched SCSI Parity, 4-31, A-5 
Latched SCSI Parity for SD15-8, 4-32, A-5 
Lost Arbitration, 4-30, A-5 
Manual Start Mode, 4-46, A-7 
Master Control for Set or Reset Pulses, 4-40, 
A-6 

Master Data Parity Error, 4-28,4-46, A-5, A-7 
Master Enable, 4-56, A-8 
Master Parity Error Enable, 4-40, A-6 
Max SCSI Synchronous Offset, 4-25, A-4 
Parity Error, 4-53, A-8 
Phase Mismatch, 4-52, A-8 
Pre-fetch Enable, 4-48, A-7 
Pre-fetch Flush, 4-48, A-7 
Reselected, 4-50,4-52, A-8 
Reset SCSI Offset, 4-61, A-9 
SACK/Status, 4-28, A-4 
SATN/Status, 4-28, A-4 
SBSY/Status, 4-28, A-4 
SC_D/Status, 4-28, A-4 
SCRIPTS Interrupt Instruction Received, 4- 
29, A-5 

SCRIPTS interrupt instruction received, 4-46, 
A-7 

SCSI C_D/ Signal, 4-31, A-5 
SCSI Control Enable, 4-61, A-9 
SCSI Data High Impedance, 4-39, A-6 
SCSI Disconnect Unexpected, 4-21, A-3 
SCSI FIFO Test Read, 4-62, A-10 
SCSI FIFO Test Write, 4-63, A-10 
SCSI Gross Error, 4-50,4-52, A-8 
SCSI High-Impedance Mode, 4-61, A-9 
SCSI I_0/Signal, 4-31, A-5 
SCSI Interrupt Pending, 4-34, A-5 
SCSI Loopback Mode, 4-61, A-9 
SCSI Low level Mode, 4-62, A-9 


SCSI MSG/ Signal, 4-31, A-5 
SCSI Parity Error, 4-50, A-8 
SCSI Phase Mismatch - Initiator Mode, 4-50, 
A-8 

SCSI Reset Condition, 4-50, A-8 
SCSI RST/ Received, 4-53, A-8 
SCSI RST/ Signal, 4-30, A-5 
SCSI SDPO/ Parity Signal, 4-30, A-5 
SCSI SDPl Signal, 4-32, A-5 
SCSI Selected As ID, 4-59, A-9 
SCSI Synchronous Offset Maximum, 4-60, A- 
9 

SCSI Synchronous Offset Zero, 4-60, A-9 
SCSI Synchronous Transfer Period, 4-24, A-4 
SCSI True End of Process, 4-37, A-6 
SCSI Valid, 4-27, A-4 

Select with SATN/ on a Start Sequence, 4-18, 
A-3 

Selected, 4-50,4-52, A-8 
Selection or Reselection Time-out, 4-51,4-53, 
A-8 

Selection Response Logic Test, 4-59, A-9 

Selection Time-Out, 4-57, A-9 

Semaphore, 4-34, A-5 

Shadow Register Test Mode, 4-39, A-6 

SI_0/ Status, 4-28, A-4 

SIDL Least Significant Byte Full, 4-30, A-5 

SIDL Most Significant Byte Full, 4-32, A-5 

Signal Process, 4-34, 4-36, A-5, A-6 

Single Step Interrupt, 4-29, A-5 

Single-step Interrupt, 4-46, A-7 

Single-step Mode, 4-48, A-7 

SLPAR High Byte Enable, 4-21, A-3 

SLPARMode, 4-21, A-3 

SMSG/Status, 4-28, A-4 

SODL Least Significant Byte Full, 4-30, A-5 

SODL Most Significant Byte Full, 4-32, A-5 

SODR Least Significant Byte Full, 4-30, A-5 

SODR Most Significant Byte Full, 4-32, A-5 

Software Reset, 4-33, A-5 

Source I/O-Memory Enable, 4-45, A-7 

SREQ/Status, 4-28, A-4 

SSEL/Status, 4-28, A-4 
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Start DMA Operation, 4-48 
Start SCSI Transfer, 4-20, A-3 
Start Sequence, 4-17, A-3 
Synchronous Clock Conversion Factor, 4-22, 
A-3 

Target Mode, 4-18, A-3 
Timer Test Mode, 4-63, A-10 
TolerANT Enable, 4-62, A-10 
Ultra SCSI Enable, 4-22, A-3 
Unexpected Disconnect, 4-50,4-53, A-8 
Wide SCSI Receive, 4-22, A-3 
Wide SCSI Send, 4-21, A-3 
Won Arbitration, 4-30, A-5 
Write and Invalidate Enable, 4-38, A-6 
Registers, 2-21 

see operating registers 
Reliability, 1-4 
REQ/, 3-8 

REQ/-GNT/, 1-1,2-2 
Request, 3-8 

Reselected bit, 4-50,4-52, A-8 
Reserved Command, 2-3 
Reset, 3-5 

Reset SCSI Offset bit, 4-61, A-9 
RESPIDO register, 4-58, A-9 
RESPIDl register, 4-59, A-9 
Response ID One register, 4-59, A-9 
Response ID 2l^ro register. 4-58, A-9 
Revision Level bits, 4-37, A-6 
ROM, 3-15 

ROM Base Address Register, 2-27 
ROM interface, 2-27 
ROM pin, 2-27 

ROM/Flash Interface Pins, 3-15 
RST/, 3-5 
RSTDIR, 3-13,3-14 

S 

SACK, 2-23 
SACK/, 3-12 

SACK/ Status bit, 4-28, A-4 
SATN/, 3-12 
SATN/Active, 4-52, A-8 
SATN/Active bit, 4-52, A-8 


SATN/ Status bit, 4-28, A-4 
SBCL register, 4-28, A-4 
SBDL register, 4-65, A-10 
SBSY Status bit, 4-28, A-4 
SBSY/, 3-12 
SC_D/, 3-12 

SC_D/ Status bit, 4-28, A-4 
scatter/gather, 1-4 
SCF2-0, 2-19 
SCID register, 4-23, A-4 
SCLK, 3-11 

SCNTLO register. 4-17, A-3 
SCNTLl Register, 2-10 
SCNTLl register, 4-19, A-3 
SCNTL2 register, 4-21, A-3 
SCNTL3 Register, 2-19 
SCNTL3 register, 4-22, A-3 
SCRATCHA register, 4-44, A-7 
SCRATCHB register, 4-65, A-10 
SCRIPT RAM, 2-2 
SCRIPTS instruction, 2-24 
SCRIPTS Interrupt Instruction Received bit, 4-29, 
A-5 

SCRIPTS Processor, 2-8 
SCRIPTS processor 

instruction prefetching, 2-9 
internal RAM for instruction storage, 2-8 
performance, 2-8 
SCRIPTS RAM. 2-8 
Scripts RAM Disable, 3-18 
SCSI 

differential mode, 2-15 
termination, 2-18 
TolerANT technology, 1-3 
SCSI ATN Condition - Target Mode, 4-50, A-8 
SCSI ATN Condition bit, 4-50, A-8 
SCSI Bus Control Lines register, 4-28, A-4 
SCSI Bus Data Lines register, 4-65, A-10 
SCSI bus interface, 2-15-?? 

SCSI C_D/ Signal bit, 4-31, A-5 
SCSI Chip ID register, 4-23, A-4 
SCSI Clock, 3-11,3-13,3-14 
SCSI Control, 3-12, 3-13, 3-14 
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SCSI Control Enable bit, 4-61, A-9 
SCSI Control One register, 4-19, A-3 
SCSI Control Three register, 4-22, A-3 
SCSI Control Two register, 4-21, A-3 
SCSI Control Zero register, 4-17, A-3 
SCSI Controller, 2-8 
SCSI core, 1-3 

SCSI Data High impedance bit, 4-39, A-6 
SCSI Destination ID register, 4-25, A-4 
SCSI Disconnect Unexpected bit, 4-21, A-3 
SCSI FIFO Test Read bit, 4-62, A-10 
SCSI FIFO Test Write bit, 4-63, A-10 
SCSI First Byte Received register, 4-26, A-4 
SCSI Gross Error bit, 4-50,4-52, A-8 
SCSI High-Impedance Mode bit, 4-61, A-9 
SCSI I_0/ Signal bit, 4-31, A-5 
SCSI Input Data Latch register, 4-64, A-10 
SCSI instructions 
block move, 5-4 
I/O, 5-8 
load/store, 5-23 
memory move, 5-20 
read/write, 5-13 
transfer control, 5-16 

SCSI Interrupt Enable One register, 4-51, A-8 
SCSI Interrupt Enable Zero register, 4-50, A-8 
SCSI Interrupt Pending bit, 4-34, A-5 
SCSI Interrupt Status One register, 4-53, A-8 
SCSI Interrupt Status Zero register, 4-52, A-8 
SCSI interrupts, 2-23 

SCSI Longitudinal Parity register, 4-54, A-8 

SCSI Loopback Mode bit, 4-61, A-9 

SCSI Low Level Mode bit, 4-62, A-9 

SCSI MSG/ Signal bit, 4-31, A-5 

SCSI Output Control Latch register, 4-27, A-4 

SCSI Output Data Latch register, 4-64, A-10 

SCSI Parity Control, 2-12 

SCSI Parity Error bit, 4-50, A-8 

SCSI Performance, 1-4 

SCSI Phase Mismatch bit, 4-50, A-8 

SCSI Reset Condition bit, 4-50, A-8 

SCSI RST/ Received bit, 4-53, A-8 

SCSI RST/Signal bit, 4-30, A-5 


SCSI SCRIPTS, 1-3 
SCSI SCRIPTS operation, 5-1 
sample instruction, 5-2 
SCSI SDPO/ Parity Signal bit, 4-30, A-5 
SCSI SDPl Signal bit, 4-32, A-5 
SCSI Selected As ID bits, 4-59, A-9 
SCSI Selector ID register, 4-27, A-4 
SCSI Serial EEPROM Access, 2-28 
SCSI Status One register, 4-31, A-5 
SCSI Status Two register, 4-32, A-5 
SCSI Status Zero register, 4-30, A-5 
SCSI Synchronous Offset Maximun, 4-60, A-9 
SCSI Synchronous Offset Zero bit, 4-60, A-9 
SCSI Test One register, 4-60, A-9 
SCSI Test Three register, 4-62, A-10 
SCSI Test Two register, 4-61, A-9 
SCSI Test Zero register, 4-59, A-9 
SCSI Timer One register, 4-58, A-9 
SCSI Timer Zero register, 4-57, A-9 
SCSI Transfer register, 4-24, A-4 
SCSI True End of Process bit, 4-37, A-6 
SCSI Valid bit, 4-27, A-4 
SCSI Wide Residue register, 4-55, A-8 
SCTRL/, 3-12,3-13,3-14 
SD/(15-0), 3-11,3-13,3-14 
SDID register, 4-25, A-4 
SDIR, 3-13 
SDIR(15-0), 3-13 
SDMS, 1-3 
SDP/(l-0), 3-11 
SEL, 2-22 

Select with SATN/ on a Start Sequence bit, 4-18, 
A-3 

Selected bit, 4-50,4-52, A-8 
Selection of Cache Line Size, 2-6 
Selection or Reselection Time-out bit, 4-51,4-53, 
A-8 

Selection Response Logic Test bits, 4-59, A-9 
Semaphore bit, 4-34, A-5 
Serial EEPROM data format, 2-28, 2-29 
Serial EEPROM Interface, 2-28 
SERR/, 3-8 

SFBR register, 4-26, A-4 
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Shadow Register Test Mode bit, 4-39, A-6 
SI_0/. 3-12 

SI_0/ Status bit. 4-28, A-4 
SID, 2-28,2-29 

SIDL Least Significant Byte Full bit, 4-30, A-5 

SIDL Most Significant Byte Full bit, 4-32, A-5 

SIDL register, 4-64, A-10 

SIENO, 2-21 

SIENO register. 4-50. A-8 

SIENl, 2-21 

SIEN1 register, 4-51, A-8 

SIGP bit, 4-34, 4-36, A-5. A-6 

Single Step Interrupt bit, 4-29, A-5 

single-ended operation, 2-15 

Single-step Interrupt bit, 4-46, A-7 

Single-step Mode bit, 4-48, A-7 

SIP. 2-21,2-23 

SISTO, 2-21,2-23,2-24 

SISTO register. 4-52, A-8 

SISTl, 2-21.2-23,2-24 

SISTl register, 4-53, A-8 

Slow ROM pin, 3-18 

SLPAR High Byte Enable, 4-21, A-3 

SLPAR Mode bit, 4-21, A-3 

SLPAR register, 4-54, A-8 

SMSG/, 3-12 

SMSG/ Status bit, 4-28, A-4 

SOCL Least Significant Byte Full bit, 4-30, A-5 

SOCL register, 4-27, A-4 

SODL Most Significant Byte Full bit, 4-32, A-5 

SODL Register, 2-24, 2-25 

SODL register, 4-64, A-10 

SODR Least Significant Byte Full bit, 4-30, A-5 

SODR Most Significant Byte Full bit, 4-32, A-5 

Software Reset bit, 4-33, A-5 

Source I/O-Memory Enable bit, 4-45, A-7 

Special Cycle Command, 2-3 

SREQ, 2-23 

SREQ/, 3-12 

SREQ/Status bit, 4-28, A-4 
SRST/, 3-12 
SSEL/, 3-12 

SSEL/Status bit, 4-28, A-4 


SSID register, 4-27, A-4 
SSTATO register, 4-30, A-5 
SSTATl register, 4-31, A-5 
SSTAT2 register, 4-32, A-5 
Stacked Interrupts, 2-23 
Start DMA Operation bit, 4-48 
Start SCSI Transfer, 4-20, A-3 
Start Sequence bit, 4-17, A-3 
STESTO register, 4-59, A-9 
STESTl register, 4-60, A-9 
STEST2 Register, 2-10 
STEST2 register. 4-61, A-9 
STEST3 register, 4-62, A-10 
STIMEO register, 4-57, A-9 
STIMEl register, 4-58, A-9 
Stop, 3-7 

Subsystem ID, 2-28, 2-29 
Subsystem Vendor ID, 2-28, 2-29 
SVID, 2-28.2-29 
SWIDE Register, 2-25 
SWIDE register, 4-55, A-8 
SXFER Register, 2-19 
SXFER register, 4-24, A-4 
SYM53C876 Benefits, 1-4 
SYM53C876 Functional Signal Grouping, 3-3 
SYM53C876 Host Interface SCSI Data Paths, 2- 
15 

Synchronous Clock Conversion Factor bits, 4-22, 
A-3 

Synchronous data transfer rates, 2-19 
Synchronous Operation, 2-19 
Synchronous SCSI Receive, 2-15 
Synchronous SCSI Send, 2-14 
Synchronous Transfer Period bits, 4-24, A-4 
System Pins, 3-5 

T 

Target Mode bit, 4-18, A-3 
Target Ready, 3-7 
TCK, 3-16 
TDI, 3-16 
TDO, 3-16 

TEMP register, 4-38, A-6 
Temporary register, 4-38, A-6 
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termination, 2-18 

Terminator Networks, 2-18 

Testability, 1-4 

TESTIN/, 3-16 

TGS, 3-13,3-14 

Timer Test Mode bit, 4-63, A-10 

timings 

Ultra SCSI, 6-61 
TMS, 3-16 

Toler ANT Enable bit, 2-20, 4-62, A-10 
TolerANT SCSI, 1-3 
TolerANT Technology, 1-3 
benefits, 1-3 

electrical characteristics, 6-8 
Extend SREQ/SACK Filtering bit. 4-62, A-9 
TolerANT Enable bit, 4-62, A-10 
TolerANT technology, 1-5 
Totem Pole Output, 3-4 
TP2-0, 2-19 

Transfer Control Instructions, 5-16 

and SCRIPTS instruction prefetching, 2-9 
transfer rate 

synchronous, 2-19 
TRDY/, 3-7 
Tri-State, 3-4 

Typical SYM53C876 Board Application, 1-2 
Typical SYM53C876 System Application, 1-2 

U 

Ultra SCSI, 1-1, 1-3 

Clock Conversion Factor bits, 4-23 
Synchronous Transfer Period bits, 4-24 
timings, 6-61 

Ultra SCSI Enable bit. 4-22, A-3 
Ultra SCSI Enable bit, 4-22, A-3 
Ultra SCSI Synchronous Data Transfers, 2-19 
Unexpected Disconnect bit, 4-50,4-53, A-8 

V 

VDD, 3-17 
VDD-C, 3-17 
VDD-IO, 3-17 
VSS, 3-17 
VSS-C, 3-17 


VSS-S, 3-17 

W 

WATN/bit, 4-18, A-3 
wide SCSI 

Always Wide SCSI bit, 4-62, A-9 
chained block moves, 2-24 
Chained Mode bit, 4-21, A-3 
Enable Wide SCSI bit. 4-23, A-3 
SWIDE register, 4-55, A-8 
Wide SCSI Receive bit, 4-22, A-3 
Wide SCSI Send bit, 4-21. A-3 
Wide SCSI Receive bit, 4-22, A-3 
Wide SCSI Send bit, 4-21, A-3 
Wide Ultra SCSI, 1-3 
Wide Ultra SCSI Benefits, 1-3 
Wide Ultra SCSI Enable bit, 2-20 
Wide Ultra SCSI Mode Enable bit. 2-19 
Wide Ultra SCSI Synchronous Data Transfers, 2- 
19 

Won Arbitration bit, 4-30, A-5 
Write and Invalidate Enable bit, 4-38, A-6 
WSRbit, 2-25 
WSSflag, 2-24 
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\orth American Sales Locations 

Western Sales Area 
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